using Statistics, Distributions, StatsBase, Optim, Roots, QuadGK, SpecialFunctions

# Toy comparison settings
wwdd = #enter directoy path here as string

include(wwdd*"/analytic_Gaussian.jl")
include(wwdd*"/multi_icml.jl")
include(wwdd*"/quasi_v2.jl")
include(wwdd*"/truncated_Laplace.jl")

# Parameters
epsilon = 2.5
delta = 0.014
Delta = 1.0
K = 5
eta = 0.01

println("=== Toy comparison (ε=", epsilon, ", δ=", delta, ", K=", K, ") ===")

# Multi-Gaussian (ICML)
sigma_MG = mG_sigma(eta_override=eta, base_max_steps=12000, base_tail_mult=10.0, quad_rtol=1e-6)
amp_MG = mG_amplitude(sigma_MG)
pow_MG = mG_power(sigma_MG)
println("Multi-Gaussian: sigma=", sigma_MG, ", L1=", amp_MG, ", L2=", pow_MG)

# Quasi-Gaussian
sigma_qG = maximum(qG_sigmas())

amp_qG = qG_amplitude(sigma_qG)
pow_qG = qG_power(sigma_qG)
println("Quasi-Gaussian: sigma=", sigma_qG, ", L1=", amp_qG, ", L2=", pow_qG)

# Analytic Gaussian
sigma_analytic = calibrateAnalyticGaussianMechanism(epsilon, delta, Delta)
amp_analytic = sigma_analytic * sqrt(2/pi)
pow_analytic = sigma_analytic^2
println("Analytic Gaussian: sigma=", sigma_analytic, ", L1=", amp_analytic, ", L2=", pow_analytic)

# Truncated Laplace
amp_trunc = TLAP(epsilon, delta, Delta)[1]
pow_trunc = TLAP(epsilon, delta, Delta)[2]
println("Truncated Laplace: L1=", amp_trunc, ", L2=", pow_trunc)

# note: all other mechanisms' original implementations are on python, so we had to write parsers to read results from Python