{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "897377c7",
   "metadata": {},
   "source": [
    "# Example 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "d2fa53aa",
   "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": "979a6995",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "u = 4*x - 3*x^2\n"
     ]
    }
   ],
   "source": [
    "@polyvar x\n",
    "u = x^2 + 4*x*(1-x)\n",
    "println(\"u = \", u)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "c618e208",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "3-element Vector{Polynomial{DynamicPolynomials.Commutative{DynamicPolynomials.CreationOrder}, Graded{LexOrder}, Int64}}:\n",
       " x\n",
       " 1 - x\n",
       " 1 - x²"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# constraint set\n",
    "## inequality constraints \n",
    "gs = [x; 1 - x; 1 - x^2]        # x >= 0; 1 - x >= 0; 1 - x^2 >= 0\n",
    "## no equality cosntraints "
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a1a3aa28",
   "metadata": {},
   "source": [
    "Check SOS monotonicity"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "5d318308",
   "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                  : 0               \n",
      "  Scalar variables       : 4               \n",
      "  Matrix variables       : 1 (scalarized: 6)\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.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            : 5               \n",
      "Optimizer  - Cones                  : 1               \n",
      "Optimizer  - Scalar variables       : 5                 conic                  : 2               \n",
      "Optimizer  - Semi-definite variables: 1                 scalarized             : 6               \n",
      "Factor     - setup time             : 0.00            \n",
      "Factor     - dense det. time        : 0.00              GP order time          : 0.00            \n",
      "Factor     - nonzeros before factor : 15                after factor           : 15              \n",
      "Factor     - dense dim.             : 0                 flops                  : 2.27e+02        \n",
      "ITE PFEAS    DFEAS    GFEAS    PRSTATUS   POBJ              DOBJ              MU       TIME  \n",
      "0   4.0e+00  1.0e+00  1.0e+00  0.00e+00   0.000000000e+00   0.000000000e+00   1.0e+00  0.00  \n",
      "1   1.5e+00  3.8e-01  2.7e-01  4.83e-01   -9.314185250e-01  -8.835985459e-01  3.8e-01  0.00  \n",
      "2   7.0e-01  1.7e-01  9.7e-02  5.02e-01   -4.483920613e+00  -4.425702729e+00  1.7e-01  0.00  \n",
      "3   5.2e-02  1.3e-02  1.8e-03  9.28e-01   -5.843295947e+00  -5.842356065e+00  1.3e-02  0.00  \n",
      "4   4.6e-05  1.1e-05  4.4e-08  1.01e+00   -5.999874562e+00  -5.999876621e+00  1.1e-05  0.00  \n",
      "5   9.7e-10  2.4e-10  9.4e-13  1.00e+00   -5.999999996e+00  -5.999999996e+00  2.4e-10  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": [
    "example1 = checkSOSMonotone([x;], [u;], gs, []; specify_degree=true, d=2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "2ceb18c3",
   "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    : -6.00000e+00\n",
      "├ Solution (result = 1)\n",
      "│ ├ primal_status        : FEASIBLE_POINT\n",
      "│ ├ dual_status          : FEASIBLE_POINT\n",
      "│ ├ objective_value      : -6.00000e+00\n",
      "│ ├ dual_objective_value : -6.00000e+00\n",
      "│ └ relative_gap         : 1.31452e-11\n",
      "└ Work counters\n",
      "  ├ solve_time (sec)   : 1.25694e-03\n",
      "  ├ simplex_iterations : 0\n",
      "  ├ barrier_iterations : 5\n",
      "  └ node_count         : 0\n"
     ]
    }
   ],
   "source": [
    "# check solution summary \n",
    "println(solution_summary(example1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "a0197e7d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "-5.999999995638667"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "lambda_max = value(example1[:t])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "85ce7632",
   "metadata": {},
   "source": [
    "The EFG in Example 1 is strictly monotone. "
   ]
  }
 ],
 "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
}
