import numpy as np
from scipy.stats import rankdata
from stage3 import stage_embedding, evaluate_kendall_abs
from experiment_utils import spectral_ordering_robust

n_points = 2000
sigma_parallel = 0.01
k = 20
n_runs = 1

for sigma_perp in [.2, 0.3, 0.4, 0.5]:
    stage_taus = []
    recanati_taus = []
    
    for run in range(n_runs):
        np.random.seed(run)
        t = np.linspace(0, 1, n_points)
        true_order = rankdata(t, method='average')
        curve_points = np.column_stack([t, np.zeros(n_points)])
        noise = np.random.normal(0, [sigma_parallel, sigma_perp], (n_points, 2))
        X = curve_points + noise
        
        _, stage_order = stage_embedding(X, k=k, embedding="laplacian")
        stage_tau = evaluate_kendall_abs(true_order, stage_order)
        stage_taus.append(stage_tau)
        
        sigma = np.sqrt(sigma_parallel**2 + sigma_perp**2)
        recanati_result = spectral_ordering_robust(X, sigma=sigma)
        recanati_order = rankdata(recanati_result, method='average')
        recanati_tau = evaluate_kendall_abs(true_order, recanati_order)
        recanati_taus.append(recanati_tau)
    
    print(f"σ_perp={sigma_perp:.1f}: STAGE={np.mean(stage_taus):.3f}±{np.std(stage_taus):.3f}, Recanati={np.mean(recanati_taus):.3f}±{np.std(recanati_taus):.3f}")
