{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "3af5d241",
   "metadata": {},
   "source": [
    "# Example 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "5c446334",
   "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": 2,
   "id": "0e841c07",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "u = 1 - 2*y - 6*x[2] - 6*x[1] + 2*x[2]*y + 2*x[1]*y + 10*x[1]*x[2]\n"
     ]
    }
   ],
   "source": [
    "@polyvar x[1:2]     # decision variables for P1\n",
    "@polyvar y          # decision variable for P2\n",
    "# The Forgetful Penalty-Shootout\n",
    "u = x[1]*x[2]*y - x[1]*x[2]*(1-y) - 5*x[1]*(1-x[2])*y - 5*x[1]*(1-x[2])*(1-y) - 5*(1-x[1])*x[2]*y - 5*(1-x[1])*x[2]*(1-y) - (1-x[1])*(1-x[2])*y + (1-x[1])*(1-x[2])*(1-y)\n",
    "println(\"u = \", u)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "63d4e804",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "monomial_basis = DynamicPolynomials.Monomial{DynamicPolynomials.Commutative{DynamicPolynomials.CreationOrder}, Graded{LexOrder}}[1, y, x₂, x₁, x₂y, x₁y, x₁x₂, x₁x₂y]\n"
     ]
    }
   ],
   "source": [
    "# monomial basis that can appear in the original EFG\n",
    "monomial_basis = vcat(monomials(u), [x[1]*x[2]*y;])\n",
    "println(\"monomial_basis = \", monomial_basis)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "16827398",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "9-element Vector{Polynomial{DynamicPolynomials.Commutative{DynamicPolynomials.CreationOrder}, Graded{LexOrder}, Int64}}:\n",
       " x₁\n",
       " x₂\n",
       " y\n",
       " 1 - x₁\n",
       " 1 - x₂\n",
       " 1 - y\n",
       " 1 - x₁²\n",
       " 1 - x₂²\n",
       " 1 - y²"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# constraint set \n",
    "## inequality constraints\n",
    "gs = [x; y; 1 .- x; 1 - y; 1 - x[1]^2; 1 - x[2]^2; 1 - y^2]       # x >= 0; y >= 0; 1 - x >= 0; 1 - y >= 0; 1 - x[1]^2 >= 0; 1 - x[2]^2 >= 0; 1 - y^2 >= 0\n",
    "## no equality cosntraints\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "671fcd6f",
   "metadata": {},
   "source": [
    "## Check SOS-concavity of the EFG"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "e5bb4a42",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Problem\n",
      "  Name                   :                 \n",
      "  Objective sense        : minimize        \n",
      "  Type                   : CONIC (conic optimization problem)\n",
      "  Constraints            : 27              \n",
      "  Affine conic cons.     : 0               \n",
      "  Disjunctive cons.      : 0               \n",
      "  Cones                  : 0               \n",
      "  Scalar variables       : 10              \n",
      "  Matrix variables       : 1 (scalarized: 28)\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            : 27              \n",
      "Optimizer  - Cones                  : 1               \n",
      "Optimizer  - Scalar variables       : 11                conic                  : 2               \n",
      "Optimizer  - Semi-definite variables: 1                 scalarized             : 28              \n",
      "Factor     - setup time             : 0.00            \n",
      "Factor     - dense det. time        : 0.00              GP order time          : 0.00            \n",
      "Factor     - nonzeros before factor : 378               after factor           : 378             \n",
      "Factor     - dense dim.             : 0                 flops                  : 1.02e+04        \n",
      "ITE PFEAS    DFEAS    GFEAS    PRSTATUS   POBJ              DOBJ              MU       TIME  \n",
      "0   2.0e+01  1.0e+00  1.0e+00  0.00e+00   0.000000000e+00   0.000000000e+00   1.0e+00  0.00  \n",
      "1   1.1e+01  5.5e-01  7.3e-01  -9.77e-01  2.127810035e+00   2.912285760e+00   5.5e-01  0.00  \n",
      "2   4.4e+00  2.2e-01  3.9e-01  -8.68e-01  1.556443006e+01   1.794364137e+01   2.2e-01  0.00  \n",
      "3   2.1e+00  1.1e-01  6.7e-02  3.35e-01   1.107894754e+01   1.115444349e+01   1.1e-01  0.00  \n",
      "4   2.7e-01  1.3e-02  1.8e-03  9.33e-01   1.021826410e+01   1.019859337e+01   1.3e-02  0.00  \n",
      "5   6.6e-04  3.3e-05  1.9e-07  1.03e+00   1.000003319e+01   9.999971400e+00   3.3e-05  0.00  \n",
      "6   6.3e-08  3.2e-09  1.8e-11  1.00e+00   1.000000013e+01   1.000000012e+01   3.2e-09  0.00  \n",
      "Optimizer terminated. Time: 0.00    \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, Random.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": [
    "example2 = checkSOSMonotone([[x;], [y;]], [u, -u], gs, []; specify_degree=true, d=2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "75f5a6a6",
   "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+01\n",
      "├ Solution (result = 1)\n",
      "│ ├ primal_status        : FEASIBLE_POINT\n",
      "│ ├ dual_status          : FEASIBLE_POINT\n",
      "│ ├ objective_value      : 1.00000e+01\n",
      "│ ├ dual_objective_value : 1.00000e+01\n",
      "│ └ relative_gap         : 6.05841e-10\n",
      "└ Work counters\n",
      "  ├ solve_time (sec)   : 1.83916e-03\n",
      "  ├ simplex_iterations : 0\n",
      "  ├ barrier_iterations : 6\n",
      "  └ node_count         : 0\n"
     ]
    }
   ],
   "source": [
    "# check solution summary \n",
    "println(solution_summary(example2))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "22d087fd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "10.000000128317419\n"
     ]
    }
   ],
   "source": [
    "println(value(example2[:t]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "938e20f4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Problem\n",
      "  Name                   :                 \n",
      "  Objective sense        : minimize        \n",
      "  Type                   : CONIC (conic optimization problem)\n",
      "  Constraints            : 182             \n",
      "  Affine conic cons.     : 0               \n",
      "  Disjunctive cons.      : 0               \n",
      "  Cones                  : 0               \n",
      "  Scalar variables       : 1               \n",
      "  Matrix variables       : 10 (scalarized: 658)\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            : 182             \n",
      "Optimizer  - Cones                  : 1               \n",
      "Optimizer  - Scalar variables       : 2                 conic                  : 2               \n",
      "Optimizer  - Semi-definite variables: 10                scalarized             : 658             \n",
      "Factor     - setup time             : 0.00            \n",
      "Factor     - dense det. time        : 0.00              GP order time          : 0.00            \n",
      "Factor     - nonzeros before factor : 1.67e+04          after factor           : 1.67e+04        \n",
      "Factor     - dense dim.             : 0                 flops                  : 2.65e+06        \n",
      "ITE PFEAS    DFEAS    GFEAS    PRSTATUS   POBJ              DOBJ              MU       TIME  \n",
      "0   2.0e+01  1.0e+00  1.0e+00  0.00e+00   0.000000000e+00   0.000000000e+00   1.0e+00  0.00  \n",
      "1   1.2e+01  6.2e-01  7.0e-01  -8.32e-01  3.275540945e+00   3.654286511e+00   6.2e-01  0.00  \n",
      "2   6.0e+00  3.0e-01  1.9e-01  7.72e-02   1.118388293e+01   1.116508443e+01   3.0e-01  0.00  \n",
      "3   1.2e+00  6.1e-02  1.2e-02  9.73e-01   1.039027554e+01   1.035032639e+01   6.1e-02  0.01  \n",
      "4   2.0e-01  1.0e-02  6.1e-04  1.35e+00   1.017620940e+01   1.016973808e+01   1.0e-02  0.01  \n",
      "5   7.5e-03  3.8e-04  5.5e-06  1.30e+00   1.000560842e+01   1.000549862e+01   3.8e-04  0.01  \n",
      "6   1.9e-04  9.7e-06  2.2e-08  1.02e+00   1.000014596e+01   1.000014304e+01   9.7e-06  0.01  \n",
      "7   7.7e-06  3.8e-07  1.7e-10  1.00e+00   1.000000588e+01   1.000000576e+01   3.8e-07  0.01  \n",
      "8   5.7e-08  2.9e-09  1.1e-13  1.00e+00   1.000000004e+01   1.000000004e+01   2.9e-09  0.01  \n",
      "Optimizer terminated. Time: 0.01    \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, Random.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": [
    "# increase the hiearchy to degree 4\n",
    "example2 = checkSOSMonotone([[x;], [y;]], [u, -u], gs, []; specify_degree=true, d=4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "cdc57955",
   "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+01\n",
      "├ Solution (result = 1)\n",
      "│ ├ primal_status        : FEASIBLE_POINT\n",
      "│ ├ dual_status          : FEASIBLE_POINT\n",
      "│ ├ objective_value      : 1.00000e+01\n",
      "│ ├ dual_objective_value : 1.00000e+01\n",
      "│ └ relative_gap         : 9.18728e-11\n",
      "└ Work counters\n",
      "  ├ solve_time (sec)   : 1.15919e-02\n",
      "  ├ simplex_iterations : 0\n",
      "  ├ barrier_iterations : 8\n",
      "  └ node_count         : 0\n"
     ]
    }
   ],
   "source": [
    "# check solution summary \n",
    "println(solution_summary(example2))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "8fad76b7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "10.000000044941958\n"
     ]
    }
   ],
   "source": [
    "println(value(example2[:t]))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6ef22baa",
   "metadata": {},
   "source": [
    "## Search for the closest SOS-monotone game"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "18a5f7fe",
   "metadata": {},
   "outputs": [],
   "source": [
    "using SumOfSquares, JuMP, MosekTools"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "31f44a80",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "A JuMP Model\n",
       "├ solver: Mosek\n",
       "├ objective_sense: FEASIBILITY_SENSE\n",
       "├ num_variables: 0\n",
       "├ num_constraints: 0\n",
       "└ Names registered in the model: none"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# create a SOS optimization model\n",
    "model = SOSModel(Mosek.Optimizer)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "eb1d4318",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "p = Polynomial{DynamicPolynomials.Commutative{DynamicPolynomials.CreationOrder}, Graded{LexOrder}, VariableRef}[(_[1]) + (_[2])y + (_[3])x₂ + (_[4])x₁ + (_[5])x₂y + (_[6])x₁y + (_[7])x₁x₂ + (_[8])x₁x₂y]\n"
     ]
    }
   ],
   "source": [
    "# create a variable for the payoff function of P1\n",
    "p = @variable(model, [1:1], Poly(monomial_basis)) # payoff for P1\n",
    "println(\"p = \", p)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "050574f1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "3×3 Matrix{Polynomial{DynamicPolynomials.Commutative{DynamicPolynomials.CreationOrder}, Graded{LexOrder}, AffExpr}}:\n",
       " 0                    (_[7]) + (_[8])y     (_[6]) + (_[8])x₂\n",
       " (_[7]) + (_[8])y     0                    (_[5]) + (_[8])x₁\n",
       " (-_[6]) + (-_[8])x₂  (-_[5]) + (-_[8])x₁  0"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# construct the Jacobian matrix \n",
    "vs = [differentiate(only(p), x); differentiate(only(-p), y)]  # pseudogradient vector\n",
    "jacobian = differentiate(vs, [x; y])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "1cbb62e0",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Basic semialgebraic Set defined by no equality\n",
       "9 inequalities\n",
       " x[1] ≥ 0\n",
       " x[2] ≥ 0\n",
       " y ≥ 0\n",
       " 1 - x[1] ≥ 0\n",
       " 1 - x[2] ≥ 0\n",
       " 1 - y ≥ 0\n",
       " 1 - x[1]^2 ≥ 0\n",
       " 1 - x[2]^2 ≥ 0\n",
       " 1 - y^2 ≥ 0\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# define the domain for x and y\n",
    "Sx = basic_semialgebraic_set(FullSpace(), gs)       # domain for (x[1], x[2], y)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "a038a3d8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Algebraic Set defined by 1 equalitty\n",
       " 1//1 - z[3]^2 - z[2]^2 - z[1]^2 = 0\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# create auxiliary polynomial variables for quadratic Jacobian z'*S*z\n",
    "@polyvar z[1:3]\n",
    "# define the domain for z\n",
    "Sz = algebraic_set([1 - z'*z])      # unit sephere for z\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "6147d9ba",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/latex": [
       "$$ (-2 {\\_}_{7})z_{1}z_{2} + (-2 {\\_}_{8})yz_{1}z_{2} \\text{ is SOS} $$"
      ],
      "text/plain": [
       "(-2 _[7])z₁z₂ + (-2 _[8])yz₁z₂ is SOS"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# construct thd SOS-monotonicity constraint. The target game is SOS-monotone\n",
    "cref = @constraint(model, - z' * jacobian * z >= 0, domain=intersect(Sx, Sz))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "c69546a7",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "16-element Vector{AffExpr}:\n",
       " _[1] - 1\n",
       " _[2] + 2\n",
       " _[3] + 6\n",
       " _[4] + 6\n",
       " _[5] - 2\n",
       " _[6] - 2\n",
       " _[7] - 10\n",
       " _[8]\n",
       " -_[1] + 1\n",
       " -_[2] - 2\n",
       " -_[3] - 6\n",
       " -_[4] - 6\n",
       " -_[5] + 2\n",
       " -_[6] + 2\n",
       " -_[7] + 10\n",
       " -_[8]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# find the difference in coefficients of the two games \n",
    "diff = vcat(coefficients.([p; -p] - [u; -u])...)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "f37f5c23",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/latex": [
       "$ {\\_}_{9} $"
      ],
      "text/plain": [
       "_[9]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# minimize the l-infinity distance between the new game and the original game\n",
    "t = @variable(model)            # t is the distance in l-infinity norm between the new game and the original game \n",
    "@constraint(model, diff .<= t)  # linearize the l-infinity norm constraint\n",
    "@constraint(model, diff .>= -t) # linearize the l-infinity norm constraint\n",
    "@objective(model, Min, t)       # minimize the l-infinity distance between the new game and the original game"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "10d2fec0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Problem\n",
      "  Name                   :                 \n",
      "  Objective sense        : minimize        \n",
      "  Type                   : CONIC (conic optimization problem)\n",
      "  Constraints            : 102             \n",
      "  Affine conic cons.     : 0               \n",
      "  Disjunctive cons.      : 0               \n",
      "  Cones                  : 0               \n",
      "  Scalar variables       : 12              \n",
      "  Matrix variables       : 7 (scalarized: 196)\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 : 3\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            : 71              \n",
      "Optimizer  - Cones                  : 0               \n",
      "Optimizer  - Scalar variables       : 7                 conic                  : 0               \n",
      "Optimizer  - Semi-definite variables: 7                 scalarized             : 196             \n",
      "Factor     - setup time             : 0.00            \n",
      "Factor     - dense det. time        : 0.00              GP order time          : 0.00            \n",
      "Factor     - nonzeros before factor : 2110              after factor           : 2281            \n",
      "Factor     - dense dim.             : 0                 flops                  : 1.32e+05        \n",
      "ITE PFEAS    DFEAS    GFEAS    PRSTATUS   POBJ              DOBJ              MU       TIME  \n",
      "0   1.1e+01  1.0e+00  1.0e+00  0.00e+00   0.000000000e+00   0.000000000e+00   1.0e+00  0.00  \n",
      "1   4.1e+00  3.7e-01  5.7e-01  -9.28e-01  1.510330616e+00   2.906739493e+00   3.7e-01  0.00  \n",
      "2   8.7e-01  7.9e-02  1.9e-01  -7.68e-01  7.180948900e+00   1.244199885e+01   7.9e-02  0.00  \n",
      "3   8.5e-02  7.8e-03  4.0e-03  4.40e-01   1.038352826e+01   1.058524681e+01   7.8e-03  0.00  \n",
      "4   4.4e-04  4.0e-05  1.0e-06  1.08e+00   1.000146713e+01   1.000177773e+01   4.0e-05  0.00  \n",
      "5   6.3e-11  5.7e-12  3.9e-17  1.00e+00   1.000000000e+01   1.000000000e+01   5.7e-12  0.00  \n",
      "Optimizer terminated. Time: 0.00    \n",
      "\n"
     ]
    }
   ],
   "source": [
    "optimize!(model)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "932ae956",
   "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+01\n",
      "├ Solution (result = 1)\n",
      "│ ├ primal_status        : FEASIBLE_POINT\n",
      "│ ├ dual_status          : FEASIBLE_POINT\n",
      "│ ├ objective_value      : 1.00000e+01\n",
      "│ ├ dual_objective_value : 1.00000e+01\n",
      "│ └ relative_gap         : 2.22222e-13\n",
      "└ Work counters\n",
      "  ├ solve_time (sec)   : 4.97508e-03\n",
      "  ├ simplex_iterations : 0\n",
      "  ├ barrier_iterations : 5\n",
      "  └ node_count         : 0\n"
     ]
    }
   ],
   "source": [
    "# check solution summary\n",
    "println(solution_summary(model))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "d5d75bdb",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "f = -9.000000000154827 - 12.000000000154827*y - 16.000000000154827*x[2] - 16.000000000154827*x[1] - 8.000000000154827*x[2]*y - 8.000000000154827*x[1]*y - 3.728573005901126e-12*x[1]*x[2] + 4.583000645652646e-12*x[1]*x[2]*y\n",
      "u = 1 - 2*y - 6*x[2] - 6*x[1] + 2*x[2]*y + 2*x[1]*y + 10*x[1]*x[2]\n"
     ]
    }
   ],
   "source": [
    "# compare the new game with the original game\n",
    "f = only(value.(p)) # the new payoff function for P1\n",
    "println(\"f = \", f)\n",
    "println(\"u = \", u)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "1f7b013c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "distance = 10.000000000154827\n"
     ]
    }
   ],
   "source": [
    "# check the minimum distance\n",
    "println(\"distance = \", value(t))"
   ]
  }
 ],
 "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
}
