import numpy as np
from typing import Dict, Optional
import matplotlib.pyplot as plt


def plot_radii_results(*,
                       results: Dict,
                       sigma: float,
                       eps_y: float,
                       confidence: float,
                       save_prefix: Optional[str] = None) -> str:
    """Render the certified radii comparison plot and save it.

    Returns the save path.
    """
    N_values = results['N_values']

    mean_empirical_variance_only = [np.mean([r['r_empirical_variance_only'] for r in results['results_by_N'][N]]) for N in N_values]
    mean_empirical_variance_gradient = [np.mean([r['r_empirical_variance_gradient'] for r in results['results_by_N'][N]]) for N in N_values]
    mean_theoretical_variance_only = [np.mean([r['r_theoretical_variance_only'] for r in results['results_by_N'][N]]) for N in N_values]
    mean_theoretical_variance_gradient = [np.mean([r['r_theoretical_variance_gradient'] for r in results['results_by_N'][N]]) for N in N_values]

    std_empirical_variance_only = [np.std([r['r_empirical_variance_only'] for r in results['results_by_N'][N]]) for N in N_values]
    std_empirical_variance_gradient = [np.std([r['r_empirical_variance_gradient'] for r in results['results_by_N'][N]]) for N in N_values]

    plt.style.use('default')
    fig, ax1 = plt.subplots(figsize=(12, 8), dpi=150)

    ax1.errorbar(N_values, mean_empirical_variance_only, yerr=std_empirical_variance_only,
                 fmt='o-', label='Empirical (Variance-Only)', color='orangered',
                 capsize=5, capthick=2, linewidth=2, markersize=8)
    ax1.errorbar(N_values, mean_empirical_variance_gradient, yerr=std_empirical_variance_gradient,
                 fmt='s-', label='Empirical (Variance + Gradient)', color='royalblue',
                 capsize=5, capthick=2, linewidth=2, markersize=8)

    ax1.axhline(np.mean(mean_theoretical_variance_only), linestyle='--', color='red',
                linewidth=3, alpha=0.8, label='Theoretical (Variance-Only)')
    ax1.axhline(np.mean(mean_theoretical_variance_gradient), linestyle='--', color='blue',
                linewidth=3, alpha=0.8, label='Theoretical (Variance + Gradient)')

    ax1.set_xlabel('Number of Samples (N)')
    ax1.set_ylabel('Mean Certified Radius')
    ax1.set_title('Empirical vs. Theoretical Certified Radii\n(Error bars show ±1 std)', pad=20)
    ax1.set_xscale('log')
    ax1.grid(True, alpha=0.3)

    ax1.legend(fontsize=12, loc='upper left', bbox_to_anchor=(1.02, 1))

    textstr = f'σ = {sigma:.1f}\nε = {eps_y:.1f}\nConfidence = {confidence:.1%}'
    props = dict(boxstyle='round', facecolor='wheat', alpha=0.8)
    ax1.text(1.02, 0.7, textstr, transform=ax1.transAxes, fontsize=10,
             verticalalignment='top', bbox=props)

    plt.tight_layout(rect=[0, 0, 0.85, 1])

    save_path = f"{save_prefix}_certified_radii.png" if save_prefix else f"certified_radii_sigma{sigma}_eps{eps_y}.png"
    plt.savefig(save_path, dpi=300, bbox_inches='tight', facecolor='white')
    plt.close(fig)
    return save_path


