{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "b1a04fe4",
   "metadata": {},
   "outputs": [],
   "source": [
    "using Random\n",
    "using DynamicPolynomials\n",
    "using SumOfSquares\n",
    "import CSDP\n",
    "import SumOfSquares.solve\n",
    "using JuMP, MosekTools, LinearAlgebra"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4aa25eca",
   "metadata": {},
   "source": [
    "Example B.4"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "ece88e57",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "p_sub = -3 + 5*y[1] + 5*x[1] + 4*y[1]^2 - 2*x[1]*y[1]\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "Basic semialgebraic Set defined by no equality\n",
       "4 inequalities\n",
       " x[1] ≥ 0\n",
       " y[1] ≥ 0\n",
       " 1 - y[1] ≥ 0\n",
       " 1 - x[1] ≥ 0\n"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "@polyvar x[1:2] y[1:2] \n",
    "p = 2+3*x[1]*y[1]-5*x[2]*y[2]+4*y[1]^2\n",
    "# we can use a substitution trick to reduce the number of variables and the degree of the polynomial\n",
    "p_sub = subs(p, x[2] => 1 - x[1], y[2] => 1 - y[1])\n",
    "println(\"p_sub = \", p_sub)\n",
    "Sx = @set x[1] >= 0 && y[1] >= 0 && y[1] <= 1 && x[1] <= 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "37883020",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Problem\n",
      "  Name                   :                 \n",
      "  Objective sense        : minimize        \n",
      "  Type                   : CONIC (conic optimization problem)\n",
      "  Constraints            : 5               \n",
      "  Affine conic cons.     : 0               \n",
      "  Disjunctive cons.      : 0               \n",
      "  Cones                  : 1               \n",
      "  Scalar variables       : 8               \n",
      "  Matrix variables       : 0               \n",
      "  Integer variables      : 0               \n",
      "\n",
      "Optimizer started.\n",
      "Presolve started.\n",
      "Eliminator - tries                  : 0                 time                   : 0.00            \n",
      "Lin. dep.  - tries                  : 0                 time                   : 0.00            \n",
      "Lin. dep.  - primal attempts        : 0                 successes              : 0               \n",
      "Lin. dep.  - dual attempts          : 0                 successes              : 0               \n",
      "Lin. dep.  - primal deps.           : 0                 dual deps.             : 0               \n",
      "Presolve terminated. Time: 0.00    \n",
      "Optimizer terminated. Time: 0.00    \n",
      "\n",
      "Solution: 0.0\n",
      "nothing"
     ]
    }
   ],
   "source": [
    "model = SOSModel(Mosek.Optimizer)\n",
    "@variable(model, t)\n",
    "@objective(model, Min, t)\n",
    "@constraint(model, c, p_sub <= t, domain = Sx, maxdegree = 2)\n",
    "optimize!(model)\n",
    "println(\"Solution: $(value(t))\")\n",
    "\n",
    "v = moment_matrix(model[:c])\n",
    "nu = atomic_measure(v, 1e-3)\n",
    "print(nu)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "f825faa4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Problem\n",
      "  Name                   :                 \n",
      "  Objective sense        : minimize        \n",
      "  Type                   : CONIC (conic optimization problem)\n",
      "  Constraints            : 10              \n",
      "  Affine conic cons.     : 0               \n",
      "  Disjunctive cons.      : 0               \n",
      "  Cones                  : 0               \n",
      "  Scalar variables       : 1               \n",
      "  Matrix variables       : 5 (scalarized: 30)\n",
      "  Integer variables      : 0               \n",
      "\n",
      "Optimizer started.\n",
      "Presolve started.\n",
      "Linear dependency checker started.\n",
      "Linear dependency checker terminated.\n",
      "Eliminator started.\n",
      "Freed constraints in eliminator : 0\n",
      "Eliminator terminated.\n",
      "Eliminator - tries                  : 1                 time                   : 0.00            \n",
      "Lin. dep.  - tries                  : 1                 time                   : 0.00            \n",
      "Lin. dep.  - primal attempts        : 1                 successes              : 1               \n",
      "Lin. dep.  - dual attempts          : 0                 successes              : 0               \n",
      "Lin. dep.  - primal deps.           : 0                 dual deps.             : 0               \n",
      "Presolve terminated. Time: 0.00    \n",
      "Optimizer  - threads                : 6               \n",
      "Optimizer  - solved problem         : the primal      \n",
      "Optimizer  - Constraints            : 10              \n",
      "Optimizer  - Cones                  : 1               \n",
      "Optimizer  - Scalar variables       : 2                 conic                  : 2               \n",
      "Optimizer  - Semi-definite variables: 5                 scalarized             : 30              \n",
      "Factor     - setup time             : 0.00            \n",
      "Factor     - dense det. time        : 0.00              GP order time          : 0.00            \n",
      "Factor     - nonzeros before factor : 54                after factor           : 55              \n",
      "Factor     - dense dim.             : 0                 flops                  : 1.51e+03        \n",
      "ITE PFEAS    DFEAS    GFEAS    PRSTATUS   POBJ              DOBJ              MU       TIME  \n",
      "0   7.0e+00  1.0e+00  1.0e+00  0.00e+00   0.000000000e+00   0.000000000e+00   1.0e+00  0.00  \n",
      "1   2.8e+00  4.0e-01  6.4e-01  -1.05e+00  2.419710345e+00   3.958921790e+00   4.0e-01  0.00  \n",
      "2   7.8e-01  1.1e-01  1.5e-01  -5.65e-01  7.984601288e+00   9.339315003e+00   1.1e-01  0.00  \n",
      "3   1.5e-01  2.2e-02  9.8e-03  1.06e+00   8.211922815e+00   8.338877152e+00   2.2e-02  0.00  \n",
      "4   6.0e-03  8.6e-04  8.7e-05  9.25e-01   8.964184741e+00   8.971431097e+00   8.6e-04  0.00  \n",
      "5   2.9e-04  4.1e-05  9.0e-07  1.01e+00   8.998502277e+00   8.998824938e+00   4.1e-05  0.00  \n",
      "6   2.4e-05  3.5e-06  2.2e-08  1.01e+00   8.999889963e+00   8.999915991e+00   3.5e-06  0.00  \n",
      "7   1.2e-06  1.7e-07  2.3e-10  1.01e+00   8.999995441e+00   8.999996678e+00   1.7e-07  0.00  \n",
      "8   2.8e-08  3.9e-09  7.9e-13  1.00e+00   8.999999938e+00   8.999999964e+00   3.9e-09  0.00  \n",
      "9   1.0e-09  1.7e-10  6.5e-15  9.92e-01   9.000000000e+00   9.000000001e+00   1.6e-10  0.00  \n",
      "Optimizer terminated. Time: 0.00    \n",
      "\n",
      "Solution: 8.999999999812859\n",
      "Atomic measure on the variables x[1], y[1] with 1 atoms:\n",
      " at [0.9999999991054458, 1.0000000001027787] with weight 1.000000000161834"
     ]
    }
   ],
   "source": [
    "model = SOSModel(Mosek.Optimizer)\n",
    "@variable(model, t)\n",
    "@objective(model, Min, t)\n",
    "@constraint(model, c, p_sub <= t, domain = Sx, maxdegree = 4)\n",
    "optimize!(model)\n",
    "println(\"Solution: $(value(t))\")\n",
    "\n",
    "v = moment_matrix(model[:c])\n",
    "nu = atomic_measure(v, 1e-2)\n",
    "print(nu)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "c4d2263f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "random_multilinear_poly_no_repeats (generic function with 1 method)"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Functions to randomly generate multilinear polynomials (with and without variable repeats in each monomial)\n",
    "# Polynomials without variable repeats in the same monomial are non-absentminded.\n",
    "\n",
    "function random_multilinear_poly(varlists; nterms=5, coeff_range=(-5,5), seed=1234)\n",
    "    Random.seed!(seed)\n",
    "    allvars = reduce(vcat, varlists)\n",
    "    n = length(allvars)\n",
    "    polys = DynamicPolynomials.zero(allvars[1])\n",
    "    terms = Set{Vector{Int}}()\n",
    "    while length(terms) < nterms\n",
    "        exps = [rand(Bool) for _ in 1:n]\n",
    "        if any(exps)\n",
    "            push!(terms, exps)\n",
    "        end\n",
    "    end\n",
    "    for exps in terms\n",
    "        coeff = rand(coeff_range[1]:coeff_range[2])\n",
    "        term = coeff*prod(allvars[i]^exps[i] for i in 1:n)\n",
    "        polys += term\n",
    "    end\n",
    "    return polys\n",
    "end\n",
    "\n",
    "function random_multilinear_poly_no_repeats(varlists; nterms=5, coeff_range=(-5,5), seed=1234)\n",
    "    Random.seed!(seed)\n",
    "    nvars = length(varlists)\n",
    "    polys = DynamicPolynomials.zero(reduce(vcat, varlists)[1])\n",
    "    terms = Set{Vector{Union{Nothing,Int}}}()\n",
    "    while length(terms) < nterms\n",
    "        choices = [rand(0:length(vs)) for vs in varlists]\n",
    "        if any(choices .> 0)\n",
    "            push!(terms, choices)\n",
    "        end\n",
    "    end\n",
    "    for choices in terms\n",
    "        coeff = rand(coeff_range[1]:coeff_range[2])\n",
    "        if coeff == 0\n",
    "            continue\n",
    "        end\n",
    "        term = coeff\n",
    "        for (i, idx) in enumerate(choices)\n",
    "            if idx > 0\n",
    "                term *= varlists[i][idx]\n",
    "            end\n",
    "        end\n",
    "        polys += term\n",
    "    end\n",
    "    return polys\n",
    "end"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ce862755",
   "metadata": {},
   "source": [
    "Example of single-player IREFG $\\mathcal{G}_1$, without infoset repeats in variables. This is a NAM game, so we should expect:\n",
    "1. Ex-ante optima at the vertices\n",
    "2. Convergence at a finite level of the hierarchy\n",
    "3. Extraction always possible at the $\\ell+1$ level"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5e13ca8b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/latex": [
       "$$ -4z_{1} + x_{2}y_{2} + x_{2}y_{2}z_{1} - 3x_{2}y_{1}z_{2} - 3x_{2}y_{1}z_{1} $$"
      ],
      "text/plain": [
       "-4z₁ + x₂y₂ + x₂y₂z₁ - 3x₂y₁z₂ - 3x₂y₁z₁"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "@polyvar x[1:2]\n",
    "@polyvar y[1:2] \n",
    "@polyvar z[1:2]\n",
    "test2 = random_multilinear_poly_no_repeats([x,y,z],nterms=6)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5528bc66",
   "metadata": {},
   "outputs": [],
   "source": [
    "gs = [x; 1 - sum(x); 1 - sum(x.^2); y; 1 - sum(y); 1 - sum(y.^2); z; 1 - sum(z); 1 - sum(z.^2)]\n",
    "hs = [sum(x) - 1; sum(y) - 1; sum(z) - 1]\n",
    "Sg = basic_semialgebraic_set(FullSpace(), gs) \n",
    "Sh = algebraic_set(hs)\n",
    "\n",
    "for var in [x, y, z]\n",
    "    Sx = intersect(Sx, algebraic_set([i*(1-i) for i in var]))\n",
    "end"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0bf82eb9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Problem\n",
      "  Name                   :                 \n",
      "  Objective sense        : minimize        \n",
      "  Type                   : CONIC (conic optimization problem)\n",
      "  Constraints            : 63              \n",
      "  Affine conic cons.     : 0               \n",
      "  Disjunctive cons.      : 0               \n",
      "  Cones                  : 0               \n",
      "  Scalar variables       : 11              \n",
      "  Matrix variables       : 1 (scalarized: 91)\n",
      "  Integer variables      : 0               \n",
      "\n",
      "Optimizer started.\n",
      "Presolve started.\n",
      "Eliminator - tries                  : 0                 time                   : 0.00            \n",
      "Lin. dep.  - tries                  : 0                 time                   : 0.00            \n",
      "Lin. dep.  - primal attempts        : 0                 successes              : 0               \n",
      "Lin. dep.  - dual attempts          : 0                 successes              : 0               \n",
      "Lin. dep.  - primal deps.           : 0                 dual deps.             : 0               \n",
      "Presolve terminated. Time: 0.00    \n",
      "Optimizer terminated. Time: 0.00    \n",
      "\n",
      "Solution: 0.0\n",
      "Atomic measure on the variables x[1], x[2], x[3], y[1], y[2], y[3], x[1], x[2], y[1], y[2], z[1], z[2] with 1 atoms:\n",
      " at [0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0] with weight 0.0"
     ]
    }
   ],
   "source": [
    "model = SOSModel(Mosek.Optimizer)\n",
    "@variable(model, t)\n",
    "@objective(model, Min, t)\n",
    "@constraint(model, c, test2 <= t, domain = Sx, maxdegree = 2)\n",
    "optimize!(model)\n",
    "println(\"Solution: $(value(t))\")\n",
    "\n",
    "v = moment_matrix(model[:c])\n",
    "nu = atomic_measure(v, 0.5e-1)\n",
    "print(nu)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b92f775e",
   "metadata": {},
   "source": [
    "In the generated example, $\\ell+1=4$ so let us try setting degree 4 of the hierarchy."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a124bba1",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Problem\n",
      "  Name                   :                 \n",
      "  Objective sense        : minimize        \n",
      "  Type                   : CONIC (conic optimization problem)\n",
      "  Constraints            : 8               \n",
      "  Affine conic cons.     : 0               \n",
      "  Disjunctive cons.      : 0               \n",
      "  Cones                  : 0               \n",
      "  Scalar variables       : 1               \n",
      "  Matrix variables       : 13 (scalarized: 742)\n",
      "  Integer variables      : 0               \n",
      "\n",
      "Optimizer started.\n",
      "Presolve started.\n",
      "Linear dependency checker started.\n",
      "Linear dependency checker terminated.\n",
      "Eliminator started.\n",
      "Freed constraints in eliminator : 0\n",
      "Eliminator terminated.\n",
      "Eliminator started.\n",
      "Freed constraints in eliminator : 0\n",
      "Eliminator terminated.\n",
      "Eliminator - tries                  : 2                 time                   : 0.00            \n",
      "Lin. dep.  - tries                  : 1                 time                   : 0.01            \n",
      "Lin. dep.  - primal attempts        : 1                 successes              : 1               \n",
      "Lin. dep.  - dual attempts          : 0                 successes              : 0               \n",
      "Lin. dep.  - primal deps.           : 0                 dual deps.             : 0               \n",
      "Presolve terminated. Time: 0.01    \n",
      "Optimizer  - threads                : 6               \n",
      "Optimizer  - solved problem         : the primal      \n",
      "Optimizer  - Constraints            : 8               \n",
      "Optimizer  - Cones                  : 1               \n",
      "Optimizer  - Scalar variables       : 2                 conic                  : 2               \n",
      "Optimizer  - Semi-definite variables: 13                scalarized             : 742             \n",
      "Factor     - setup time             : 0.00            \n",
      "Factor     - dense det. time        : 0.00              GP order time          : 0.00            \n",
      "Factor     - nonzeros before factor : 36                after factor           : 36              \n",
      "Factor     - dense dim.             : 0                 flops                  : 1.20e+05        \n",
      "ITE PFEAS    DFEAS    GFEAS    PRSTATUS   POBJ              DOBJ              MU       TIME  \n",
      "0   1.8e+01  1.0e+00  1.0e+00  0.00e+00   0.000000000e+00   0.000000000e+00   1.0e+00  0.05  \n",
      "1   7.1e+00  3.9e-01  2.5e-01  1.18e+00   -6.243006529e-01  -5.980895671e-01  3.9e-01  0.05  \n",
      "2   1.9e+00  1.0e-01  3.8e-02  5.26e-01   -6.595858283e-01  -6.458501854e-01  1.0e-01  0.05  \n",
      "3   7.8e-01  4.3e-02  1.1e-02  8.65e-01   3.968832987e-01   4.059442347e-01   4.3e-02  0.06  \n",
      "4   3.0e-02  1.7e-03  9.0e-05  1.03e+00   9.591207754e-01   9.599552932e-01   1.7e-03  0.06  \n",
      "5   1.4e-03  7.8e-05  9.1e-07  9.94e-01   9.986494090e-01   9.986896972e-01   7.8e-05  0.06  \n",
      "6   6.6e-05  3.7e-06  9.3e-09  9.95e-01   9.999566124e-01   9.999586256e-01   3.7e-06  0.06  \n",
      "7   2.6e-06  1.4e-07  7.1e-11  9.97e-01   9.999986515e-01   9.999987312e-01   1.4e-07  0.06  \n",
      "8   5.1e-08  2.9e-09  2.0e-13  1.00e+00   9.999999785e-01   9.999999801e-01   2.9e-09  0.06  \n",
      "Optimizer terminated. Time: 0.06    \n",
      "\n",
      "Solution: 0.9999999785163505\n",
      "Atomic measure on the variables x[1], x[2], y[1], y[2], z[1], z[2] with 1 atoms:\n",
      " at [0.0, 0.9999999970099273, 0.0, 0.9999999994781928, 0.0, 0.9999999992745031] with weight 0.9999999950680244"
     ]
    }
   ],
   "source": [
    "model = SOSModel(Mosek.Optimizer)\n",
    "@variable(model, t)\n",
    "@objective(model, Min, t)\n",
    "@constraint(model, c, test2 <= t, domain = Sx, maxdegree = 4)\n",
    "optimize!(model)\n",
    "println(\"Solution: $(value(t))\")\n",
    "\n",
    "v = moment_matrix(model[:c])\n",
    "nu = atomic_measure(v, 1e-2)\n",
    "print(nu)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9d517003",
   "metadata": {},
   "source": [
    "Example for a randomly generated single-player IREFG $\\mathcal{G}_1$. Note that we do not disallow repeats of infosets, so this game is considered absent-minded. Theoretically, we expect asymptotic convergence to the ex-ante optimum value."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "97d1effb",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/latex": [
       "$$ 4x_{1}x_{3} + 2x_{2}x_{3}y_{3} - 5x_{1}x_{2}y_{3} + x_{1}x_{2}y_{1} - 4x_{2}x_{3}y_{2}y_{3} $$"
      ],
      "text/plain": [
       "4x₁x₃ + 2x₂x₃y₃ - 5x₁x₂y₃ + x₁x₂y₁ - 4x₂x₃y₂y₃"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "@polyvar x[1:3]\n",
    "@polyvar y[1:3] \n",
    "test1 = random_multilinear_poly([x,y],nterms=5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "3c451aca",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Basic semialgebraic Set defined by 2 equalities\n",
       " -1//1 + x[3] + x[2] + x[1] = 0\n",
       " -1//1 + y[3] + y[2] + y[1] = 0\n",
       "10 inequalities\n",
       " x[1] ≥ 0\n",
       " x[2] ≥ 0\n",
       " x[3] ≥ 0\n",
       " 1//1 - x[3] - x[2] - x[1] ≥ 0\n",
       " 1//1 - x[3]^2 - x[2]^2 - x[1]^2 ≥ 0\n",
       " y[1] ≥ 0\n",
       " y[2] ≥ 0\n",
       " y[3] ≥ 0\n",
       " 1//1 - y[3] - y[2] - y[1] ≥ 0\n",
       " 1//1 - y[3]^2 - y[2]^2 - y[1]^2 ≥ 0\n"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "gs = [x; 1 - sum(x); 1 - sum(x.^2); y; 1 - sum(y); 1 - sum(y.^2)]\n",
    "hs = [sum(x) - 1; sum(y) - 1]\n",
    "Sg = basic_semialgebraic_set(FullSpace(), gs) \n",
    "Sh = algebraic_set(hs)\n",
    "Sx = intersect(Sh, Sg)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "d8ea2ea8",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Problem\n",
      "  Name                   :                 \n",
      "  Objective sense        : minimize        \n",
      "  Type                   : CONIC (conic optimization problem)\n",
      "  Constraints            : 20              \n",
      "  Affine conic cons.     : 0               \n",
      "  Disjunctive cons.      : 0               \n",
      "  Cones                  : 0               \n",
      "  Scalar variables       : 11              \n",
      "  Matrix variables       : 1 (scalarized: 28)\n",
      "  Integer variables      : 0               \n",
      "\n",
      "Optimizer started.\n",
      "Presolve started.\n",
      "Eliminator - tries                  : 0                 time                   : 0.00            \n",
      "Lin. dep.  - tries                  : 0                 time                   : 0.00            \n",
      "Lin. dep.  - primal attempts        : 0                 successes              : 0               \n",
      "Lin. dep.  - dual attempts          : 0                 successes              : 0               \n",
      "Lin. dep.  - primal deps.           : 0                 dual deps.             : 0               \n",
      "Presolve terminated. Time: 0.00    \n",
      "Optimizer terminated. Time: 0.01    \n",
      "\n",
      "Solution: 0.0\n",
      "Atomic measure on the variables x[1], x[2], x[3], y[1], y[2], y[3] with 1 atoms:\n",
      " at [0.0, 0.0, 0.0, 0.0, 0.0, 0.0] with weight 0.0"
     ]
    }
   ],
   "source": [
    "\n",
    "model = SOSModel(Mosek.Optimizer)\n",
    "@variable(model, t)\n",
    "@objective(model, Min, t)\n",
    "@constraint(model, c, test1 <= t, domain = Sx, maxdegree = 2)\n",
    "optimize!(model)\n",
    "println(\"Solution: $(value(t))\")\n",
    "\n",
    "v = moment_matrix(model[:c])\n",
    "nu = atomic_measure(v, 0.5e-1)\n",
    "print(nu)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "7b796e4b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Problem\n",
      "  Name                   :                 \n",
      "  Objective sense        : minimize        \n",
      "  Type                   : CONIC (conic optimization problem)\n",
      "  Constraints            : 70              \n",
      "  Affine conic cons.     : 0               \n",
      "  Disjunctive cons.      : 0               \n",
      "  Cones                  : 0               \n",
      "  Scalar variables       : 1               \n",
      "  Matrix variables       : 11 (scalarized: 686)\n",
      "  Integer variables      : 0               \n",
      "\n",
      "Optimizer started.\n",
      "Presolve started.\n",
      "Linear dependency checker started.\n",
      "Linear dependency checker terminated.\n",
      "Eliminator started.\n",
      "Freed constraints in eliminator : 0\n",
      "Eliminator terminated.\n",
      "Eliminator - tries                  : 1                 time                   : 0.00            \n",
      "Lin. dep.  - tries                  : 1                 time                   : 0.00            \n",
      "Lin. dep.  - primal attempts        : 1                 successes              : 1               \n",
      "Lin. dep.  - dual attempts          : 0                 successes              : 0               \n",
      "Lin. dep.  - primal deps.           : 0                 dual deps.             : 0               \n",
      "Presolve terminated. Time: 0.00    \n",
      "Optimizer  - threads                : 6               \n",
      "Optimizer  - solved problem         : the primal      \n",
      "Optimizer  - Constraints            : 70              \n",
      "Optimizer  - Cones                  : 1               \n",
      "Optimizer  - Scalar variables       : 2                 conic                  : 2               \n",
      "Optimizer  - Semi-definite variables: 11                scalarized             : 686             \n",
      "Factor     - setup time             : 0.00            \n",
      "Factor     - dense det. time        : 0.00              GP order time          : 0.00            \n",
      "Factor     - nonzeros before factor : 2485              after factor           : 2485            \n",
      "Factor     - dense dim.             : 0                 flops                  : 1.04e+06        \n",
      "ITE PFEAS    DFEAS    GFEAS    PRSTATUS   POBJ              DOBJ              MU       TIME  \n",
      "0   1.2e+01  1.0e+00  1.0e+00  0.00e+00   0.000000000e+00   0.000000000e+00   1.0e+00  0.03  \n",
      "1   6.5e+00  5.4e-01  3.7e-01  -2.87e-02  8.708865114e-01   7.755565145e-01   5.4e-01  0.03  \n",
      "2   2.5e+00  2.1e-01  6.3e-02  1.59e+00   1.229327972e+00   1.167694775e+00   2.1e-01  0.05  \n",
      "3   6.6e-01  5.5e-02  7.5e-03  1.43e+00   1.069384271e+00   1.055553609e+00   5.5e-02  0.05  \n",
      "4   2.3e-01  1.9e-02  1.4e-03  1.30e+00   1.034991602e+00   1.030816418e+00   1.9e-02  0.05  \n",
      "5   5.9e-02  4.9e-03  1.8e-04  1.15e+00   1.017259377e+00   1.016218460e+00   4.9e-03  0.05  \n",
      "6   1.9e-02  1.6e-03  3.4e-05  1.01e+00   1.011242948e+00   1.010899471e+00   1.6e-03  0.05  \n",
      "7   5.1e-03  4.3e-04  4.8e-06  9.68e-01   1.008989402e+00   1.008899338e+00   4.3e-04  0.05  \n",
      "8   1.8e-03  1.5e-04  1.1e-06  9.41e-01   1.008096713e+00   1.008062823e+00   1.5e-04  0.05  \n",
      "9   6.3e-04  5.2e-05  2.1e-07  9.74e-01   1.007773831e+00   1.007762013e+00   5.2e-05  0.05  \n",
      "10  1.4e-04  1.2e-05  2.2e-08  9.76e-01   1.007563564e+00   1.007560770e+00   1.2e-05  0.05  \n",
      "11  1.8e-05  1.5e-06  1.0e-09  9.95e-01   1.007515052e+00   1.007514692e+00   1.5e-06  0.05  \n",
      "12  4.0e-07  3.3e-08  3.4e-12  9.99e-01   1.007507106e+00   1.007507098e+00   3.3e-08  0.05  \n",
      "13  2.3e-08  2.0e-09  4.5e-14  1.00e+00   1.007506939e+00   1.007506938e+00   1.9e-09  0.05  \n",
      "Optimizer terminated. Time: 0.05    \n",
      "\n",
      "Solution: 1.0075069388210154\n",
      "Atomic measure on the variables x[1], x[2], x[3], y[1], y[2], y[3] with 2 atoms:\n",
      " at [0.4886331389822651, 0.053899843847066045, 0.4574670171702122, 0.16215584773608732, 0.9043790077138709, -0.06653485545019747] with weight 0.4045299429883002\n",
      " at [0.480550683558932, -0.00011970792986664217, 0.519569024371092, 0.06541992113398093, 0.15600580916642942, 0.7785742696998523] with weight 0.5757192384734691"
     ]
    }
   ],
   "source": [
    "model = SOSModel(Mosek.Optimizer)\n",
    "@variable(model, t)\n",
    "@objective(model, Min, t)\n",
    "@constraint(model, c, test1 <= t, domain = Sx, maxdegree = 4)\n",
    "optimize!(model)\n",
    "println(\"Solution: $(value(t))\")\n",
    "\n",
    "v = moment_matrix(model[:c])\n",
    "nu = atomic_measure(v, 1e-2)\n",
    "print(nu)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "67c5f6ad",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Problem\n",
      "  Name                   :                 \n",
      "  Objective sense        : minimize        \n",
      "  Type                   : CONIC (conic optimization problem)\n",
      "  Constraints            : 210             \n",
      "  Affine conic cons.     : 0               \n",
      "  Disjunctive cons.      : 0               \n",
      "  Cones                  : 0               \n",
      "  Scalar variables       : 1               \n",
      "  Matrix variables       : 11 (scalarized: 7630)\n",
      "  Integer variables      : 0               \n",
      "\n",
      "Optimizer started.\n",
      "Presolve started.\n",
      "Linear dependency checker started.\n",
      "Linear dependency checker terminated.\n",
      "Eliminator started.\n",
      "Freed constraints in eliminator : 0\n",
      "Eliminator terminated.\n",
      "Eliminator - tries                  : 1                 time                   : 0.00            \n",
      "Lin. dep.  - tries                  : 1                 time                   : 0.00            \n",
      "Lin. dep.  - primal attempts        : 1                 successes              : 1               \n",
      "Lin. dep.  - dual attempts          : 0                 successes              : 0               \n",
      "Lin. dep.  - primal deps.           : 0                 dual deps.             : 0               \n",
      "Presolve terminated. Time: 0.00    \n",
      "GP based matrix reordering started.\n",
      "GP based matrix reordering terminated.\n",
      "Optimizer  - threads                : 6               \n",
      "Optimizer  - solved problem         : the primal      \n",
      "Optimizer  - Constraints            : 210             \n",
      "Optimizer  - Cones                  : 1               \n",
      "Optimizer  - Scalar variables       : 2                 conic                  : 2               \n",
      "Optimizer  - Semi-definite variables: 11                scalarized             : 7630            \n",
      "Factor     - setup time             : 0.00            \n",
      "Factor     - dense det. time        : 0.00              GP order time          : 0.00            \n",
      "Factor     - nonzeros before factor : 2.22e+04          after factor           : 2.22e+04        \n",
      "Factor     - dense dim.             : 0                 flops                  : 7.03e+07        \n",
      "ITE PFEAS    DFEAS    GFEAS    PRSTATUS   POBJ              DOBJ              MU       TIME  \n",
      "0   2.2e+01  1.0e+00  1.0e+00  0.00e+00   0.000000000e+00   0.000000000e+00   1.0e+00  0.02  \n",
      "1   1.1e+01  5.2e-01  2.9e-01  5.27e-01   5.937791144e-01   4.280339483e-01   5.2e-01  0.03  \n",
      "2   3.9e+00  1.8e-01  3.6e-02  2.04e+00   8.731030778e-01   8.215135393e-01   1.8e-01  0.05  \n",
      "3   7.3e-01  3.3e-02  2.5e-03  1.69e+00   9.926424208e-01   9.857456357e-01   3.3e-02  0.06  \n",
      "4   1.0e-01  4.5e-03  9.2e-05  1.27e+00   1.002992730e+00   1.001970478e+00   4.5e-03  0.08  \n",
      "5   1.0e-02  4.6e-04  2.2e-06  1.29e+00   1.000399478e+00   1.000299448e+00   4.6e-04  0.09  \n",
      "6   2.0e-03  9.2e-05  2.0e-07  1.07e+00   1.000080623e+00   1.000061520e+00   9.2e-05  0.11  \n",
      "7   5.5e-04  2.5e-05  3.1e-08  9.92e-01   1.000027792e+00   1.000022730e+00   2.5e-05  0.12  \n",
      "8   1.6e-04  7.4e-06  5.3e-09  9.32e-01   1.000014977e+00   1.000013476e+00   7.4e-06  0.14  \n",
      "9   4.6e-05  2.1e-06  9.1e-10  8.44e-01   1.000008759e+00   1.000008307e+00   2.1e-06  0.16  \n",
      "10  1.4e-05  6.5e-07  1.8e-10  8.30e-01   1.000006191e+00   1.000006044e+00   6.5e-07  0.17  \n",
      "11  6.0e-06  2.7e-07  5.6e-11  6.26e-01   1.000004551e+00   1.000004482e+00   2.7e-07  0.19  \n",
      "12  1.8e-06  8.2e-08  1.2e-11  5.91e-01   1.000003226e+00   1.000003204e+00   8.2e-08  0.20  \n",
      "13  4.9e-07  2.2e-08  2.3e-12  6.23e-01   1.000002396e+00   1.000002391e+00   2.3e-08  0.23  \n",
      "14  3.2e-07  7.5e-09  8.1e-13  3.56e-01   1.000001773e+00   1.000001775e+00   7.7e-09  0.25  \n",
      "15  1.1e-07  2.5e-09  1.6e-13  8.71e-01   1.000001786e+00   1.000001787e+00   2.5e-09  0.30  \n",
      "16  7.9e-08  8.0e-10  2.8e-14  8.71e-01   1.000001784e+00   1.000001785e+00   7.8e-10  0.31  \n",
      "17  2.5e-08  3.0e-10  5.1e-15  9.94e-01   1.000001751e+00   1.000001751e+00   2.5e-10  0.33  \n",
      "18  2.3e-08  2.6e-10  3.9e-15  9.96e-01   1.000001748e+00   1.000001748e+00   2.1e-10  0.36  \n",
      "19  2.2e-08  2.4e-10  3.4e-15  9.96e-01   1.000001747e+00   1.000001747e+00   1.9e-10  0.38  \n",
      "20  1.7e-08  2.4e-10  1.7e-15  9.96e-01   1.000001744e+00   1.000001744e+00   1.2e-10  0.41  \n",
      "Optimizer terminated. Time: 0.41    \n",
      "\n",
      "Solution: 1.0000017439806979\n",
      "Atomic measure on the variables x[1], x[2], x[3], y[1], y[2], y[3] with 1 atoms:\n",
      " at [0.4999970534091429, 7.176336707469788e-6, 0.4999957702538686, 0.1340646344553113, 0.5940083935876702, 0.2719269719565363] with weight 0.9901853567323881"
     ]
    }
   ],
   "source": [
    "model = SOSModel(Mosek.Optimizer)\n",
    "@variable(model, t)\n",
    "@objective(model, Min, t)\n",
    "@constraint(model, c, test1 <= t, domain = Sx, maxdegree = 6)\n",
    "optimize!(model)\n",
    "println(\"Solution: $(value(t))\")\n",
    "\n",
    "v = moment_matrix(model[:c])\n",
    "nu = atomic_measure(v, 1e-2)\n",
    "print(nu)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Julia 1.11.3",
   "language": "julia",
   "name": "julia-1.11"
  },
  "language_info": {
   "file_extension": ".jl",
   "mimetype": "application/julia",
   "name": "julia",
   "version": "1.11.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
