import numpy as np
import matplotlib.pyplot as plt

# Simulated performance data (replace with actual results)




datasets = ['Cora', 'CiteSeer', 'PubMed', 'PPI']
methods = ['GBM', 'GCN', 'GAT', 'GraphSAGE', 'ChebNet']
accuracy = {
    'GBM': [85.08, 78, 82, 76],
    'GCN': [81, 73, 79, 72],
    'GAT': [83, 76, 80, 74],
    'GraphSAGE': [80, 74, 78, 73],
    'ChebNet': [82, 75, 81, 75]
}
std = {
    'GBM': [0.79, 0.03, 0.025, 0.028],
    'GCN': [0.03, 0.04, 0.035, 0.032],
    'GAT': [0.025, 0.035, 0.03, 0.029],
    'GraphSAGE': [0.035, 0.038, 0.032, 0.03],
    'ChebNet': [0.028, 0.036, 0.031, 0.027]
}

# Plotting configuration
plt.style.use('seaborn')  # Professional style
plt.rcParams.update({
    'font.size': 12,
    'axes.labelsize': 14,
    'axes.titlesize': 16,
    'xtick.labelsize': 12,
    'ytick.labelsize': 12,
    'legend.fontsize': 12,
    'figure.figsize': (10, 6),  # Wider figure for multiple methods
    'axes.grid': True,
    'grid.alpha': 0.5
})

# Colors and markers for each method
colors = ['tab:blue', 'tab:orange', 'tab:green', 'tab:red', 'tab:purple']
markers = ['o', 's', '^', 'D', 'v']

# Create figure and axis
fig, ax = plt.subplots()

# Plot scatter points with error bars for each method
x = np.arange(len(datasets))  # Dataset positions
for i, method in enumerate(methods):
    ax.errorbar(x + i * 0.1 - 0.2, accuracy[method], yerr=std[method],
                label=method, color=colors[i], marker=markers[i],
                linestyle='none', capsize=5, markersize=8)

# Customize plot
ax.set_xlabel('Dataset')
ax.set_ylabel('Accuracy')
ax.set_title('Accuracy Comparison of GBM and Baseline Methods with Standard Deviation')
ax.set_xticks(x)
ax.set_xticklabels(datasets)
ax.set_ylim(60, 95)  # Adjust y-axis range for clarity
ax.legend(bbox_to_anchor=(1.05, 1), loc='upper left')

# Adjust layout to prevent label cutoff
plt.tight_layout()

# Save plot in high resolution for publication
plt.savefig('accuracy_std_comparison_scatter.png', dpi=300, bbox_inches='tight')
plt.savefig('accuracy_std_comparison_scatter.pdf', format='pdf', dpi=300, bbox_inches='tight')
plt.close()

print("Visualization saved as 'accuracy_std_comparison_scatter.pdf'")