{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "62a04748",
   "metadata": {},
   "source": [
    "# Example 3"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "c9f83d02",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "checkSOSMonotone (generic function with 1 method)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "using DynamicPolynomials\n",
    "include(\"../scripts/SOSGameClass.jl\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "7cac18a8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "highDegreeConvexPolynomial (generic function with 1 method)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "include(\"../scripts/HighDegreeConvexPolynomial.jl\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "a5beefa3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(Variable{DynamicPolynomials.Commutative{DynamicPolynomials.CreationOrder}, Graded{LexOrder}}[x₁, x₂], Variable{DynamicPolynomials.Commutative{DynamicPolynomials.CreationOrder}, Graded{LexOrder}}[y₁, y₂])"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "@polyvar x[1:2] y[1:2]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f8a278a2",
   "metadata": {},
   "source": [
    "## Generate degree-4 concave polynomials"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "7ff633e2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# parameter for the coefficient of the quadratic terms\n",
    "lambda = 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "bd589744",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Random number generator reseeded with seed: 1234\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",
      "Random number generator reseeded with seed: 5678\n",
      "f(x, y) = 6.8278881469732555*y[2]^4 + 6.8278881469732555*y[1]^2*y[2]^2 + 6.8278881469732555*y[1]^4 + 0.8534860183716569*x[2]^2*y[2]^2 + 0.8630999497196777*x[2]^2*y[1]*y[2] + 0.5324098005567357*x[2]^2*y[1]^2 + 6.8278881469732555*x[2]^4 + 1.090938075337132*x[1]*x[2]*y[2]^2 + 1.6988256373982287*x[1]*x[2]*y[1]*y[2] + 0.41181929031338477*x[1]*x[2]*y[1]^2 + 0.3886486621379131*x[1]^2*y[2]^2 + 0.9770968942006956*x[1]^2*y[1]*y[2] + 0.6141269492710042*x[1]^2*y[1]^2 + 6.8278881469732555*x[1]^2*x[2]^2 + 6.8278881469732555*x[1]^4\n",
      "Payoff functions for P1: -0.5*y[2]^2 - 0.5*y[1]^2 - 0.5*x[2]^2 - 0.5*x[1]^2 - 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",
      "Payoff functions for P2: -0.5*y[2]^2 - 0.5*y[1]^2 - 0.5*x[2]^2 - 0.5*x[1]^2 - 6.8278881469732555*y[2]^4 - 6.8278881469732555*y[1]^2*y[2]^2 - 6.8278881469732555*y[1]^4 - 0.8534860183716569*x[2]^2*y[2]^2 - 0.8630999497196777*x[2]^2*y[1]*y[2] - 0.5324098005567357*x[2]^2*y[1]^2 - 6.8278881469732555*x[2]^4 - 1.090938075337132*x[1]*x[2]*y[2]^2 - 1.6988256373982287*x[1]*x[2]*y[1]*y[2] - 0.41181929031338477*x[1]*x[2]*y[1]^2 - 0.3886486621379131*x[1]^2*y[2]^2 - 0.9770968942006956*x[1]^2*y[1]*y[2] - 0.6141269492710042*x[1]^2*y[1]^2 - 6.8278881469732555*x[1]^2*x[2]^2 - 6.8278881469732555*x[1]^4\n"
     ]
    }
   ],
   "source": [
    "# generate two degree-4 concave polynomials\n",
    "us = - [highDegreeConvexPolynomial(x, y, 1, 1; seed=1234), highDegreeConvexPolynomial(x, y, 1, 1; seed=5678)] .- [x; y]' * [x; y] * lambda * 0.5\n",
    "\n",
    "println(\"Payoff functions for P1: \", us[1])\n",
    "println(\"Payoff functions for P2: \", us[2])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "53be5713",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "DynamicPolynomials.Monomial{DynamicPolynomials.Commutative{DynamicPolynomials.CreationOrder}, Graded{LexOrder}}[y₂², y₁², x₂², x₁², y₂⁴, y₁²y₂², y₁⁴, x₂²y₂², x₂²y₁y₂, x₂²y₁², x₂⁴, x₁x₂y₂², x₁x₂y₁y₂, x₁x₂y₁², x₁²y₂², x₁²y₁y₂, x₁²y₁², x₁²x₂², x₁⁴]\n"
     ]
    }
   ],
   "source": [
    "# print the polynomial basis \n",
    "println(monomials(sum(us)))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9c1a6161",
   "metadata": {},
   "source": [
    "## Check SOS-monotonicity"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "ccb16d19",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "8-element Vector{Polynomial{DynamicPolynomials.Commutative{DynamicPolynomials.CreationOrder}, Graded{LexOrder}, Int64}}:\n",
       " x₁\n",
       " x₂\n",
       " 1 - x₂ - x₁\n",
       " 1 - x₂² - x₁²\n",
       " y₁\n",
       " y₂\n",
       " 1 - y₂ - y₁\n",
       " 1 - y₂² - y₁²"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# construct the domain\n",
    "gs = [x; 1 - sum(x); 1 - sum(x.^2); y; 1 - sum(y); 1 - sum(y.^2)]       # x >= 0; 1 - sum(x) >= 0 1 - sum(x.^2) >= 0; 1 - sum(y) >= 0; 1 - sum(y.^2) >= 0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "40efb2e7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Problem\n",
      "  Name                   :                 \n",
      "  Objective sense        : minimize        \n",
      "  Type                   : CONIC (conic optimization problem)\n",
      "  Constraints            : 450             \n",
      "  Affine conic cons.     : 0               \n",
      "  Disjunctive cons.      : 0               \n",
      "  Cones                  : 0               \n",
      "  Scalar variables       : 1               \n",
      "  Matrix variables       : 9 (scalarized: 1395)\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                : 8               \n",
      "Optimizer  - solved problem         : the primal      \n",
      "Optimizer  - Constraints            : 450             \n",
      "Optimizer  - Cones                  : 1               \n",
      "Optimizer  - Scalar variables       : 2                 conic                  : 2               \n",
      "Optimizer  - Semi-definite variables: 9                 scalarized             : 1395            \n",
      "Factor     - setup time             : 0.00            \n",
      "Factor     - dense det. time        : 0.00              GP order time          : 0.00            \n",
      "Factor     - nonzeros before factor : 1.01e+05          after factor           : 1.01e+05        \n",
      "Factor     - dense dim.             : 0                 flops                  : 3.42e+07        \n",
      "ITE PFEAS    DFEAS    GFEAS    PRSTATUS   POBJ              DOBJ              MU       TIME  \n",
      "0   1.1e+02  1.0e+00  1.0e+00  0.00e+00   0.000000000e+00   0.000000000e+00   1.0e+00  0.00  \n",
      "1   4.3e+01  3.8e-01  6.0e-01  -9.85e-01  2.198679106e+01   2.344461447e+01   3.8e-01  0.01  \n",
      "2   6.7e+00  6.0e-02  2.1e-01  -9.50e-01  1.510717913e+02   1.618219513e+02   6.0e-02  0.01  \n",
      "3   2.4e+00  2.2e-02  2.9e-02  2.04e-01   5.371273442e+01   5.526195236e+01   2.2e-02  0.02  \n",
      "4   6.4e-01  5.7e-03  2.5e-03  1.86e+00   8.424812869e+00   8.574766924e+00   5.7e-03  0.02  \n",
      "5   9.6e-02  8.6e-04  8.5e-05  1.33e+00   3.176751306e-01   3.230489992e-01   8.6e-04  0.02  \n",
      "6   1.9e-02  1.7e-04  7.9e-06  1.19e+00   -7.696841251e-01  -7.681978422e-01  1.7e-04  0.03  \n",
      "7   3.1e-03  2.8e-05  5.4e-07  1.07e+00   -9.621933576e-01  -9.619411871e-01  2.8e-05  0.03  \n",
      "8   7.7e-04  6.9e-06  6.6e-08  1.02e+00   -9.904197497e-01  -9.903594092e-01  6.9e-06  0.03  \n",
      "9   1.3e-04  1.2e-06  4.4e-09  1.01e+00   -9.984448582e-01  -9.984353431e-01  1.2e-06  0.04  \n",
      "10  3.5e-05  3.1e-07  6.0e-10  1.00e+00   -9.995868228e-01  -9.995843377e-01  3.1e-07  0.04  \n",
      "11  5.3e-06  4.8e-08  3.2e-11  1.00e+00   -9.999407780e-01  -9.999405266e-01  4.8e-08  0.04  \n",
      "12  1.3e-06  1.1e-08  4.0e-12  1.00e+00   -9.999853288e-01  -9.999852532e-01  1.1e-08  0.05  \n",
      "13  5.2e-07  2.3e-09  3.6e-13  1.00e+00   -9.999969847e-01  -9.999969695e-01  2.3e-09  0.05  \n",
      "14  5.2e-08  3.1e-10  1.7e-14  1.03e+00   -9.999996301e-01  -9.999996281e-01  3.0e-10  0.05  \n",
      "Optimizer terminated. Time: 0.05    \n",
      "\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "A JuMP Model\n",
       "├ solver: Mosek\n",
       "├ objective_sense: MIN_SENSE\n",
       "│ └ objective_function_type: VariableRef\n",
       "├ num_variables: 1\n",
       "├ num_constraints: 1\n",
       "│ └ Vector{AffExpr} in SumOfSquares.SOSPolynomialSet{BasicSemialgebraicSet{Rational{BigInt}, Polynomial{DynamicPolynomials.Commutative{DynamicPolynomials.CreationOrder}, Graded{LexOrder}, Rational{BigInt}}, AlgebraicSet{Rational{BigInt}, Polynomial{DynamicPolynomials.Commutative{DynamicPolynomials.CreationOrder}, Graded{LexOrder}, Rational{BigInt}}, Buchberger, SemialgebraicSets.SolverUsingMultiplicationMatrices{SemialgebraicSets.GröbnerBasisMultiplicationMatricesAlgorithm, ReorderedSchurMultiplicationMatricesSolver{Int64, TaskLocalRNG}}, BigFloat}}, DynamicPolynomials.Monomial{DynamicPolynomials.Commutative{DynamicPolynomials.CreationOrder}, Graded{LexOrder}}, MonomialVector{DynamicPolynomials.Commutative{DynamicPolynomials.CreationOrder}, Graded{LexOrder}}, SumOfSquares.Certificate.Putinar{SumOfSquares.Certificate.MaxDegree{SOSCone, MonomialBasis}, SumOfSquares.Certificate.MaxDegree{SOSCone, MonomialBasis}}}: 1\n",
       "└ Names registered in the model\n",
       "  └ :cref, :t"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "example3 = checkSOSMonotone([[x;], [y;]], us, gs, []; specify_degree=true, d=4)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "e9f2376d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "solution_summary(; result = 1, verbose = false)\n",
      "├ solver_name          : Mosek\n",
      "├ Termination\n",
      "│ ├ termination_status : OPTIMAL\n",
      "│ ├ result_count       : 1\n",
      "│ ├ raw_status         : Mosek.MSK_SOL_STA_OPTIMAL\n",
      "│ └ objective_bound    : -1.00000e+00\n",
      "├ Solution (result = 1)\n",
      "│ ├ primal_status        : FEASIBLE_POINT\n",
      "│ ├ dual_status          : FEASIBLE_POINT\n",
      "│ ├ objective_value      : -1.00000e+00\n",
      "│ ├ dual_objective_value : -1.00000e+00\n",
      "│ └ relative_gap         : 1.96008e-09\n",
      "└ Work counters\n",
      "  ├ solve_time (sec)   : 5.36799e-02\n",
      "  ├ simplex_iterations : 0\n",
      "  ├ barrier_iterations : 14\n",
      "  └ node_count         : 0\n"
     ]
    }
   ],
   "source": [
    "# check solution summary \n",
    "println(solution_summary(example3))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "a95b00d1",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "lambda_max = -0.9999996301032257\n"
     ]
    }
   ],
   "source": [
    "lambda_max = value(example3[:t])\n",
    "println(\"lambda_max = \", lambda_max)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "519d224f",
   "metadata": {},
   "source": [
    "This EFG is strictly SOS-monotone."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "83f2b84c",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Julia 1.11.4",
   "language": "julia",
   "name": "julia-1.11"
  },
  "language_info": {
   "file_extension": ".jl",
   "mimetype": "application/julia",
   "name": "julia",
   "version": "1.11.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
