using JuMP, Ipopt, BenchmarkTools, MathOptInterface
const MOI = MathOptInterface

function solve_minimax(nx::Int, nt::Int)
    # Create a silent Ipopt model
    model = Model(Ipopt.Optimizer)
    set_silent(model)

    # x[0] through x[nx-1]
    @variable(model, x[i = 0:nx-1])

    # t[1] through t[nt], bounded in [-2,2]
    @variable(model, -2 <= t[i = 1:nt] <= 2)

    # Objective: minimize x[0]
    @NLobjective(model, Min, x[0])

    # Nonlinear constraints
    @NLconstraint(model, 
        tcons1, 
        -( x[1] + x[2]*t[1] + x[3]*t[1]^2 + x[4]*t[1]^3 + x[5]*sin(t[1]) + x[6]*cos(t[1]) ) 
        + (1 - exp(-t[1]^2)) 
        - x[0] <= 0
    )
    @NLconstraint(model, 
        tcons2, 
          x[1] + x[2]*t[1] + x[3]*t[1]^2 + x[4]*t[1]^3 + x[5]*sin(t[1]) + x[6]*cos(t[1])
        - (1 - exp(-t[1]^2))
        - x[0] <= 0
    )

    # Solve
    optimize!(model)
    status = termination_status(model)
    if status == MOI.OPTIMAL || status == MOI.LOCALLY_SOLVED
        x0 = value(x[0])
        xv = Dict(i => value(x[i]) for i in 0:nx-1)
        tv = Dict(i => value(t[i]) for i in 1:nt)
        return x0, xv, tv
    else
        error("Solver failed with status $status")
    end
end

# Parameters
const NX = 7
const NT = 1

# Benchmark and run once
bench = @benchmark solve_minimax($NX, $NT)
opt_val, x_dict, t_dict = solve_minimax(NX, NT)

# Print results
println("Optimal objective (x[0])  = ", opt_val)
println("Optimal x-values: ")
for i in 0:NX-1
    println("  x[$i] = ", x_dict[i])
end
println("Optimal t-values: ")
for i in 1:NT
    println("  t[$i] = ", t_dict[i])
end

# Show benchmark summary
println("\nBenchmark (solve_minimax) — median time: ",
        median(bench).time/1_000_000, " ms; allocations: ", median(bench).allocs)
