{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "a441c87f",
   "metadata": {},
   "outputs": [],
   "source": [
    "using DynamicPolynomials, JuMP, SumOfSquares, Random, Distributions, Combinatorics, MosekTools"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "4423d524",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "highDegreeConvexPolynomial (generic function with 1 method)"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Function to create a random psd polynomial\n",
    "function create_psd_b(x, y, p, q; seed::Union{Nothing, Integer}=nothing)\n",
    "    n = length(x)\n",
    "    m = length(y)\n",
    "\n",
    "    # Set the random seed for reproducibility\n",
    "    if seed !== nothing\n",
    "        Random.seed!(seed)\n",
    "        println(\"Random number generator reseeded with seed: $seed\")\n",
    "    else \n",
    "        println(\"No seed provided, using default random number generator.\")\n",
    "    end\n",
    "\n",
    "    # Create a random psd polynomial b(x, y)\n",
    "    M_y = sum([rand(Uniform(-1, 1), n, n) * y[i]^q for i in 1:m])\n",
    "    println(\"M_y = \", M_y)\n",
    "    b = only(x'.^p * M_y' * M_y * x.^p) # b(x, y) is psd\n",
    "    println(\"b(x, y) = \", b)\n",
    "    \n",
    "    return b\n",
    "end\n",
    "\n",
    "#  Function to create a high-degree convex polynomial f(x, y), based on Ahamadi et al. (2013)\n",
    "function highDegreeConvexPolynomial(x::Vector, y::Vector, p::Integer, q::Integer; seed::Union{Nothing, Integer}=nothing)\n",
    "    # Get the dimensions of x and y\n",
    "    n = length(x)\n",
    "    m = length(y)\n",
    "    \n",
    "    # Check the input\n",
    "    if n < 1 || m < 1\n",
    "        throw(ArgumentError(\"n and m must be greater than or equal to 1.\"))\n",
    "    end\n",
    "\n",
    "    if p < 1 || q < 1\n",
    "        throw(ArgumentError(\"p and q must be greater than or equal to 1.\"))\n",
    "    end\n",
    "\n",
    "    if p % 2 == 0 || q % 2 == 0\n",
    "        throw(ArgumentError(\"p and q must be odd integers.\"))\n",
    "    end \n",
    "\n",
    "    # Create a psd polynomial b(x, y)\n",
    "    b = create_psd_b(x, y, p, q; seed=seed)\n",
    "\n",
    "    # Get the values of λ, μ, and ν\n",
    "    lambda = maximum([maximum.(coefficients.(differentiate(differentiate(b, x), y))); - minimum.(coefficients.(differentiate(differentiate(b, x), y)))])\n",
    "    mu = p == 1 ? 0 : maximum([maximum.(coefficients.(differentiate(b, x, 2))); - minimum.(coefficients.(differentiate(b, x, 2)))])\n",
    "    nu = q == 1 ? 0 : maximum([maximum.(coefficients.(differentiate(b, y, 2))); - minimum.(coefficients.(differentiate(b, y, 2)))])\n",
    "\n",
    "    println(\"lambda = \", lambda)\n",
    "    println(\"mu = \", mu)\n",
    "    println(\"nu = \", nu)\n",
    "\n",
    "    # Construct g(x, y), h(x, y), and w(x, y)\n",
    "    g = m^2 * lambda / (2 * p * (2*p - 1)) * sum(prod.(collect(with_replacement_combinations(x.^(2*p), 2)))) + n^2 * lambda / (2 * q * (2*q - 1)) * sum(prod.(collect(with_replacement_combinations(y.^(2*q), 2))))\n",
    "    if p == 1 && q == 1\n",
    "        h = 0\n",
    "        w = 0\n",
    "    elseif p > 1 && q == 1\n",
    "        h = m * (m+1) * mu / (4 * p * (p+1)) * sum(prod.(collect(with_replacement_combinations(x.^(p+1), 2)))) + mu / (2 * (p-1) * (p-2)) * sum(prod.(collect(with_replacement_combinations(x.^(p-1), 2)))) * sum(prod.(collect(with_replacement_combinations(y.^(2*q), 2))))\n",
    "        w = 2 * m^2 * q * mu / ((p-1) * (p-2) * (2*p-3)) * sum(prod.(collect(with_replacement_combinations(x.^(2*p-2), 2)))) + n^2 * mu / ((p-2) * (4*q-1)) * sum(prod.(collect(with_replacement_combinations(y.^(4*q), 2))))\n",
    "    elseif p == 1 && q > 1\n",
    "        h = n * (n+1) * nu / (4 * q * (q+1)) * sum(prod.(collect(with_replacement_combinations(y.^(q+1), 2)))) + nu / (2 * (q-1) * (q-2)) * sum(prod.(collect(with_replacement_combinations(y.^(q-1), 2)))) * sum(prod.(collect(with_replacement_combinations(x.^(2*p), 2))))\n",
    "        w = 2 * n^2 * p * nu / ((q-1) * (q-2) * (2*q-3)) * sum(prod.(collect(with_replacement_combinations(y.^(2*q-2), 2)))) + m^2 * nu / ((q-2) * (4*p-1)) * sum(prod.(collect(with_replacement_combinations(x.^(4*p), 2))))\n",
    "    else    # p > 1 && q > 1\n",
    "        h = m * (m+1) * mu / (4 * p * (p+1)) * sum(prod.(collect(with_replacement_combinations(x.^(p+1), 2)))) + mu / (2 * (p-1) * (p-2)) * sum(prod.(collect(with_replacement_combinations(x.^(p-1), 2)))) * sum(prod.(collect(with_replacement_combinations(y.^(2*q), 2)))) + n * (n+1) * nu / (4 * q * (q+1)) * sum(prod.(collect(with_replacement_combinations(y.^(q+1), 2)))) + nu / (2 * (q-1) * (q-2)) * sum(prod.(collect(with_replacement_combinations(y.^(q-1), 2)))) * sum(prod.(collect(with_replacement_combinations(x.^(2*p), 2))))\n",
    "        w = 2 * m^2 * q * mu / ((p-1) * (p-2) * (2*p-3)) * sum(prod.(collect(with_replacement_combinations(x.^(2*p-2), 2)))) + m^2 * nu / ((q-2) * (4*p-1)) * sum(prod.(collect(with_replacement_combinations(x.^(4*p), 2)))) + 2 * n^2 * p * nu / ((q-1) * (q-2) * (2*q-3)) * sum(prod.(collect(with_replacement_combinations(y.^(2*q-2), 2)))) + n^2 * mu / ((p-2) * (4*q-1)) * sum(prod.(collect(with_replacement_combinations(y.^(4*q), 2))))\n",
    "    end \n",
    "\n",
    "    println(\"g(x, y) = \", g)\n",
    "    println(\"h(x, y) = \", h)\n",
    "    println(\"w(x, y) = \", w)\n",
    "    \n",
    "    # Construct f(x, y)\n",
    "    f = b + g + h + w\n",
    "    println(\"f(x, y) = \", f)\n",
    "\n",
    "    return f\n",
    "end"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a267e465",
   "metadata": {},
   "source": [
    "Example single player, SOS-Monotone game $\\mathcal{G}_{\\rm SOS}$, with degree 4. "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "99956097",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Random number generator reseeded with seed: 1234\n",
      "M_y = Polynomial{DynamicPolynomials.Commutative{DynamicPolynomials.CreationOrder}, Graded{LexOrder}, Float64}[-0.2937767112015759y₂ - 0.3480465422728103y₁ 0.9062492545696843y₂ - 0.5628266903623387y₁; -0.21148926516829847y₂ + 0.0981022726311338y₁ 0.5910938950694389y₂ + 0.7884908564019766y₁]\n",
      "b(x, y) = 1.1706797041964692*x[2]^2*y[2]^2 - 0.0879782741110201*x[2]^2*y[1]*y[2] + 0.9384917140137463*x[2]^2*y[1]^2 - 0.782489878100129*x[1]*x[2]*y[2]^2 - 0.5176824855737008*x[1]*x[2]*y[1]*y[2] + 0.546485256882729*x[1]*x[2]*y[1]^2 + 0.13103246532584098*x[1]^2*y[2]^2 + 0.1630007819677758*x[1]^2*y[1]*y[2] + 0.13076045148345242*x[1]^2*y[1]^2\n",
      "lambda = 4.682718816785877\n",
      "mu = 0\n",
      "nu = 0\n",
      "g(x, y) = 9.365437633571753*y[2]^4 + 9.365437633571753*y[1]^2*y[2]^2 + 9.365437633571753*y[1]^4 + 9.365437633571753*x[2]^4 + 9.365437633571753*x[1]^2*x[2]^2 + 9.365437633571753*x[1]^4\n",
      "h(x, y) = 0\n",
      "w(x, y) = 0\n",
      "f(x, y) = 9.365437633571753*y[2]^4 + 9.365437633571753*y[1]^2*y[2]^2 + 9.365437633571753*y[1]^4 + 1.1706797041964692*x[2]^2*y[2]^2 - 0.0879782741110201*x[2]^2*y[1]*y[2] + 0.9384917140137463*x[2]^2*y[1]^2 + 9.365437633571753*x[2]^4 - 0.782489878100129*x[1]*x[2]*y[2]^2 - 0.5176824855737008*x[1]*x[2]*y[1]*y[2] + 0.546485256882729*x[1]*x[2]*y[1]^2 + 0.13103246532584098*x[1]^2*y[2]^2 + 0.1630007819677758*x[1]^2*y[1]*y[2] + 0.13076045148345242*x[1]^2*y[1]^2 + 9.365437633571753*x[1]^2*x[2]^2 + 9.365437633571753*x[1]^4\n"
     ]
    },
    {
     "data": {
      "text/latex": [
       "$$ 9.365437633571753y_{2}^{4} + 9.365437633571753y_{1}^{2}y_{2}^{2} + 9.365437633571753y_{1}^{4} + 1.1706797041964692x_{2}^{2}y_{2}^{2} - 0.0879782741110201x_{2}^{2}y_{1}y_{2} + 0.9384917140137463x_{2}^{2}y_{1}^{2} + 9.365437633571753x_{2}^{4} - 0.782489878100129x_{1}x_{2}y_{2}^{2} - 0.5176824855737008x_{1}x_{2}y_{1}y_{2} + 0.546485256882729x_{1}x_{2}y_{1}^{2} + 0.13103246532584098x_{1}^{2}y_{2}^{2} + 0.1630007819677758x_{1}^{2}y_{1}y_{2} + 0.13076045148345242x_{1}^{2}y_{1}^{2} + 9.365437633571753x_{1}^{2}x_{2}^{2} + 9.365437633571753x_{1}^{4} $$"
      ],
      "text/plain": [
       "9.365437633571753y₂⁴ + 9.365437633571753y₁²y₂² + 9.365437633571753y₁⁴ + 1.1706797041964692x₂²y₂² - 0.0879782741110201x₂²y₁y₂ + 0.9384917140137463x₂²y₁² + 9.365437633571753x₂⁴ - 0.782489878100129x₁x₂y₂² - 0.5176824855737008x₁x₂y₁y₂ + 0.546485256882729x₁x₂y₁² + 0.13103246532584098x₁²y₂² + 0.1630007819677758x₁²y₁y₂ + 0.13076045148345242x₁²y₁² + 9.365437633571753x₁²x₂² + 9.365437633571753x₁⁴"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "@polyvar x[1:2] y[1:2]\n",
    "p = 1\n",
    "q = 1\n",
    "\n",
    "f = highDegreeConvexPolynomial(x, y, p, q; seed=1234)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "c6c2afd3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Basic semialgebraic Set defined by 2 equalities\n",
       " -1//1 + x[2] + x[1] = 0\n",
       " -1//1 + y[2] + y[1] = 0\n",
       "8 inequalities\n",
       " x[1] ≥ 0\n",
       " x[2] ≥ 0\n",
       " 1//1 - x[2] - x[1] ≥ 0\n",
       " 1//1 - x[2]^2 - x[1]^2 ≥ 0\n",
       " y[1] ≥ 0\n",
       " y[2] ≥ 0\n",
       " 1//1 - y[2] - y[1] ≥ 0\n",
       " 1//1 - 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": "markdown",
   "id": "e46b4d73",
   "metadata": {},
   "source": [
    "The problem, though high dimensional, is solved with a single SDP"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "30b70a3e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Problem\n",
      "  Name                   :                 \n",
      "  Objective sense        : minimize        \n",
      "  Type                   : CONIC (conic optimization problem)\n",
      "  Constraints            : 15              \n",
      "  Affine conic cons.     : 0               \n",
      "  Disjunctive cons.      : 0               \n",
      "  Cones                  : 0               \n",
      "  Scalar variables       : 1               \n",
      "  Matrix variables       : 9 (scalarized: 240)\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            : 15              \n",
      "Optimizer  - Cones                  : 1               \n",
      "Optimizer  - Scalar variables       : 2                 conic                  : 2               \n",
      "Optimizer  - Semi-definite variables: 9                 scalarized             : 240             \n",
      "Factor     - setup time             : 0.00            \n",
      "Factor     - dense det. time        : 0.00              GP order time          : 0.00            \n",
      "Factor     - nonzeros before factor : 120               after factor           : 120             \n",
      "Factor     - dense dim.             : 0                 flops                  : 6.28e+04        \n",
      "ITE PFEAS    DFEAS    GFEAS    PRSTATUS   POBJ              DOBJ              MU       TIME  \n",
      "0   3.1e+01  1.0e+00  1.0e+00  0.00e+00   0.000000000e+00   0.000000000e+00   1.0e+00  0.00  \n",
      "1   1.5e+01  5.0e-01  7.9e-01  -1.10e+00  1.898576405e+00   3.250790761e+00   5.0e-01  0.00  \n",
      "2   7.9e+00  2.6e-01  4.1e-01  -1.03e+00  1.532243976e+01   1.705727151e+01   2.6e-01  0.00  \n",
      "3   3.5e+00  1.1e-01  1.2e-01  2.50e-01   1.501604278e+01   1.573521859e+01   1.1e-01  0.00  \n",
      "4   4.8e-01  1.6e-02  4.0e-03  6.48e-01   1.960139878e+01   1.961249114e+01   1.6e-02  0.00  \n",
      "5   1.0e-01  3.4e-03  4.9e-04  1.12e+00   1.962572228e+01   1.963512056e+01   3.4e-03  0.00  \n",
      "6   9.9e-03  3.2e-04  1.9e-05  9.97e-01   1.990602193e+01   1.990859028e+01   3.2e-04  0.00  \n",
      "7   2.3e-05  7.5e-07  2.2e-09  1.00e+00   1.990151997e+01   1.990152595e+01   7.5e-07  0.00  \n",
      "8   2.0e-08  6.3e-10  5.1e-14  1.00e+00   1.990155496e+01   1.990155497e+01   6.3e-10  0.00  \n",
      "Optimizer terminated. Time: 0.00    \n",
      "\n",
      "Solution: 19.901554962152368\n",
      "Atomic measure on the variables x[1], x[2], y[1], y[2] with 1 atoms:\n",
      " at [0.0, 0.9999999987882228, 6.537833156799519e-8, 0.9999999346216656] with weight 0.9999999920068346"
     ]
    }
   ],
   "source": [
    "model = SOSModel(Mosek.Optimizer)\n",
    "@variable(model, t)\n",
    "@objective(model, Min, t)\n",
    "@constraint(model, c, f <= 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, 0.5e-1)\n",
    "print(nu)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9663fbdd",
   "metadata": {},
   "source": [
    "Degree 12 example"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "ff7cab23",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Random number generator reseeded with seed: 1\n",
      "M_y = Polynomial{DynamicPolynomials.Commutative{DynamicPolynomials.CreationOrder}, Graded{LexOrder}, Float64}[0.8298580073256627y₂³ - 0.8532672910614143y₁³ 0.5403606957713327y₂³ + 0.397653367382937y₁³; -0.6143837675082491y₂³ - 0.3015170208856277y₁³ 0.5610385273503726y₂³ + 0.25652948068500336y₁³]\n",
      "b(x, y) = 0.6067539107059536*x[2]^2*y[2]^6 + 0.7175983446806546*x[2]^2*y[1]^3*y[2]^3 + 0.22393557505150657*x[2]^2*y[1]^6 + 0.2074593721582101*x[1]*x[2]*y[2]^6 - 0.9156929804061068*x[1]*x[2]*y[1]^3*y[2]^3 - 0.8333052327075348*x[1]*x[2]*y[1]^6 + 1.06613172610015*x[1]^2*y[2]^6 - 1.0456870612336324*x[1]^2*y[1]^3*y[2]^3 + 0.8189775838790283*x[1]^2*y[1]^6\n",
      "lambda = 12.793580713201798\n",
      "mu = 0\n",
      "nu = 31.983951783004496\n",
      "g(x, y) = 25.587161426403597*x[2]^4 + 25.587161426403597*x[1]^2*x[2]^2 + 25.587161426403597*x[1]^4 + 1.7058107617602398*y[2]^12 + 1.7058107617602398*y[1]^6*y[2]^6 + 1.7058107617602398*y[1]^12\n",
      "h(x, y) = 3.997993972875562*y[2]^8 + 3.997993972875562*y[1]^4*y[2]^4 + 3.997993972875562*y[1]^8 + 7.995987945751124*x[2]^4*y[2]^4 + 7.995987945751124*x[2]^4*y[1]^2*y[2]^2 + 7.995987945751124*x[2]^4*y[1]^4 + 7.995987945751124*x[1]^2*x[2]^2*y[2]^4 + 7.995987945751124*x[1]^2*x[2]^2*y[1]^2*y[2]^2 + 7.995987945751124*x[1]^2*x[2]^2*y[1]^4 + 7.995987945751124*x[1]^4*y[2]^4 + 7.995987945751124*x[1]^4*y[1]^2*y[2]^2 + 7.995987945751124*x[1]^4*y[1]^4\n",
      "w(x, y) = 42.64526904400599*y[2]^8 + 42.64526904400599*y[1]^4*y[2]^4 + 42.64526904400599*y[1]^8 + 42.64526904400599*x[2]^8 + 42.64526904400599*x[1]^4*x[2]^4 + 42.64526904400599*x[1]^8\n",
      "f(x, y) = 25.587161426403597*x[2]^4 + 25.587161426403597*x[1]^2*x[2]^2 + 25.587161426403597*x[1]^4 + 46.643263016881555*y[2]^8 + 46.643263016881555*y[1]^4*y[2]^4 + 46.643263016881555*y[1]^8 + 0.6067539107059536*x[2]^2*y[2]^6 + 0.7175983446806546*x[2]^2*y[1]^3*y[2]^3 + 0.22393557505150657*x[2]^2*y[1]^6 + 7.995987945751124*x[2]^4*y[2]^4 + 7.995987945751124*x[2]^4*y[1]^2*y[2]^2 + 7.995987945751124*x[2]^4*y[1]^4 + 42.64526904400599*x[2]^8 + 0.2074593721582101*x[1]*x[2]*y[2]^6 - 0.9156929804061068*x[1]*x[2]*y[1]^3*y[2]^3 - 0.8333052327075348*x[1]*x[2]*y[1]^6 + 1.06613172610015*x[1]^2*y[2]^6 - 1.0456870612336324*x[1]^2*y[1]^3*y[2]^3 + 0.8189775838790283*x[1]^2*y[1]^6 + 7.995987945751124*x[1]^2*x[2]^2*y[2]^4 + 7.995987945751124*x[1]^2*x[2]^2*y[1]^2*y[2]^2 + 7.995987945751124*x[1]^2*x[2]^2*y[1]^4 + 7.995987945751124*x[1]^4*y[2]^4 + 7.995987945751124*x[1]^4*y[1]^2*y[2]^2 + 7.995987945751124*x[1]^4*y[1]^4 + 42.64526904400599*x[1]^4*x[2]^4 + 42.64526904400599*x[1]^8 + 1.7058107617602398*y[2]^12 + 1.7058107617602398*y[1]^6*y[2]^6 + 1.7058107617602398*y[1]^12\n"
     ]
    },
    {
     "data": {
      "text/latex": [
       "$$ 25.587161426403597x_{2}^{4} + 25.587161426403597x_{1}^{2}x_{2}^{2} + 25.587161426403597x_{1}^{4} + 46.643263016881555y_{2}^{8} + 46.643263016881555y_{1}^{4}y_{2}^{4} + 46.643263016881555y_{1}^{8} + 0.6067539107059536x_{2}^{2}y_{2}^{6} + 0.7175983446806546x_{2}^{2}y_{1}^{3}y_{2}^{3} + 0.22393557505150657x_{2}^{2}y_{1}^{6} + 7.995987945751124x_{2}^{4}y_{2}^{4} + 7.995987945751124x_{2}^{4}y_{1}^{2}y_{2}^{2} + 7.995987945751124x_{2}^{4}y_{1}^{4} + 42.64526904400599x_{2}^{8} + 0.2074593721582101x_{1}x_{2}y_{2}^{6} - 0.9156929804061068x_{1}x_{2}y_{1}^{3}y_{2}^{3} - 0.8333052327075348x_{1}x_{2}y_{1}^{6} + 1.06613172610015x_{1}^{2}y_{2}^{6} - 1.0456870612336324x_{1}^{2}y_{1}^{3}y_{2}^{3} + 0.8189775838790283x_{1}^{2}y_{1}^{6} + 7.995987945751124x_{1}^{2}x_{2}^{2}y_{2}^{4} + 7.995987945751124x_{1}^{2}x_{2}^{2}y_{1}^{2}y_{2}^{2} + 7.995987945751124x_{1}^{2}x_{2}^{2}y_{1}^{4} + 7.995987945751124x_{1}^{4}y_{2}^{4} + 7.995987945751124x_{1}^{4}y_{1}^{2}y_{2}^{2} + 7.995987945751124x_{1}^{4}y_{1}^{4} + 42.64526904400599x_{1}^{4}x_{2}^{4} + 42.64526904400599x_{1}^{8} + 1.7058107617602398y_{2}^{12} + 1.7058107617602398y_{1}^{6}y_{2}^{6} + 1.7058107617602398y_{1}^{12} $$"
      ],
      "text/plain": [
       "25.587161426403597x₂⁴ + 25.587161426403597x₁²x₂² + 25.587161426403597x₁⁴ + 46.643263016881555y₂⁸ + 46.643263016881555y₁⁴y₂⁴ + 46.643263016881555y₁⁸ + 0.6067539107059536x₂²y₂⁶ + 0.7175983446806546x₂²y₁³y₂³ + 0.22393557505150657x₂²y₁⁶ + 7.995987945751124x₂⁴y₂⁴ + 7.995987945751124x₂⁴y₁²y₂² + 7.995987945751124x₂⁴y₁⁴ + 42.64526904400599x₂⁸ + 0.2074593721582101x₁x₂y₂⁶ - 0.9156929804061068x₁x₂y₁³y₂³ - 0.8333052327075348x₁x₂y₁⁶ + 1.06613172610015x₁²y₂⁶ - 1.0456870612336324x₁²y₁³y₂³ + 0.8189775838790283x₁²y₁⁶ + 7.995987945751124x₁²x₂²y₂⁴ + 7.995987945751124x₁²x₂²y₁²y₂² + 7.995987945751124x₁²x₂²y₁⁴ + 7.995987945751124x₁⁴y₂⁴ + 7.995987945751124x₁⁴y₁²y₂² + 7.995987945751124x₁⁴y₁⁴ + 42.64526904400599x₁⁴x₂⁴ + 42.64526904400599x₁⁸ + 1.7058107617602398y₂¹² + 1.7058107617602398y₁⁶y₂⁶ + 1.7058107617602398y₁¹²"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "@polyvar x[1:2] y[1:2]\n",
    "p = 1\n",
    "q = 3\n",
    "\n",
    "f = highDegreeConvexPolynomial(x, y, p, q; seed=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "0bd1d4f9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Problem\n",
      "  Name                   :                 \n",
      "  Objective sense        : minimize        \n",
      "  Type                   : CONIC (conic optimization problem)\n",
      "  Constraints            : 91              \n",
      "  Affine conic cons.     : 0               \n",
      "  Disjunctive cons.      : 0               \n",
      "  Cones                  : 0               \n",
      "  Scalar variables       : 1               \n",
      "  Matrix variables       : 9 (scalarized: 86163)\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            : 91              \n",
      "Optimizer  - Cones                  : 1               \n",
      "Optimizer  - Scalar variables       : 2                 conic                  : 2               \n",
      "Optimizer  - Semi-definite variables: 9                 scalarized             : 86163           \n",
      "Factor     - setup time             : 0.06            \n",
      "Factor     - dense det. time        : 0.00              GP order time          : 0.00            \n",
      "Factor     - nonzeros before factor : 4186              after factor           : 4186            \n",
      "Factor     - dense dim.             : 0                 flops                  : 1.45e+09        \n",
      "ITE PFEAS    DFEAS    GFEAS    PRSTATUS   POBJ              DOBJ              MU       TIME  \n",
      "0   2.0e+02  1.0e+00  1.0e+00  0.00e+00   0.000000000e+00   0.000000000e+00   1.0e+00  0.19  \n",
      "1   8.6e+01  4.4e-01  1.0e+00  -1.61e+00  3.200805671e+00   7.121459499e+00   4.4e-01  0.28  \n",
      "2   5.6e+01  2.9e-01  6.8e-01  -2.28e+00  2.525500114e+01   2.976367588e+01   2.9e-01  0.38  \n",
      "3   1.3e+01  6.4e-02  2.4e-01  -1.09e+00  9.461412516e+01   1.079533402e+02   6.4e-02  0.47  \n",
      "4   3.3e+00  1.7e-02  1.8e-02  8.42e-01   1.080670810e+02   1.090892054e+02   1.7e-02  0.56  \n",
      "5   3.6e-01  1.8e-03  7.3e-04  8.90e-01   1.230085580e+02   1.231452154e+02   1.8e-03  0.66  \n",
      "6   7.8e-02  4.0e-04  7.3e-05  9.87e-01   1.248980595e+02   1.249279588e+02   4.0e-04  0.75  \n",
      "7   2.0e-02  1.0e-04  1.0e-05  9.94e-01   1.255161953e+02   1.255248258e+02   1.0e-04  0.84  \n",
      "8   1.9e-04  9.9e-07  9.7e-09  9.99e-01   1.256419897e+02   1.256420743e+02   9.9e-07  0.94  \n",
      "9   3.3e-07  1.7e-09  5.8e-13  1.00e+00   1.256436228e+02   1.256436229e+02   1.7e-09  1.03  \n",
      "10  1.8e-09  7.3e-10  4.0e-17  1.00e+00   1.256436239e+02   1.256436239e+02   2.8e-12  1.12  \n",
      "Optimizer terminated. Time: 1.14    \n",
      "\n",
      "Solution: 125.64362391936166\n",
      "Atomic measure on the variables x[1], x[2], y[1], y[2] with 1 atoms:\n",
      " at [0.9999999997807958, 0.0, 0.0, 0.9999999996133788] with weight 1.0000000035787713"
     ]
    }
   ],
   "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)\n",
    "\n",
    "model = SOSModel(Mosek.Optimizer)\n",
    "@variable(model, t)\n",
    "@objective(model, Min, t)\n",
    "@constraint(model, c, f <= t, domain = Sx, maxdegree = 12)\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": null,
   "id": "622d482b",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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
}
