{
 "cells": [
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## choose proper b for running"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [],
   "source": [
    "import cvxpy as cp\n",
    "import numpy as np\n",
    "import os,sys\n",
    "sys.path.append(\"..\")\n",
    "def solve_slater_point(Q, alpha, s, Dinv_half, solSavePath = None):\n",
    "    n = Q.shape[0]\n",
    "    x = cp.Variable(n)\n",
    "    obj = cp.Minimize(0.5 * cp.quad_form(x, Q) - alpha * s @ (Dinv_half @ x))\n",
    "    prob = cp.Problem(obj)\n",
    "    prob.solve(verbose = True)\n",
    "    if solSavePath is not None:\n",
    "        if not os.path.exists(solSavePath):\n",
    "            np.save(solSavePath, x.value)\n",
    "        else:\n",
    "            print(\"Slater point already exists!\\n\")\n",
    "    return x.value, prob.status\n",
    "\n",
    "def solve_opt(Q, alpha, s, Dinv_half, b, D_half, solSavePath = None):\n",
    "    n = Q.shape[0]\n",
    "    x = cp.Variable(n)\n",
    "    obj = cp.Minimize(cp.norm(D_half@x,1))\n",
    "    con = [0.5 * cp.quad_form(x, Q) - alpha * s @ (Dinv_half @ x) <= b]\n",
    "    prob = cp.Problem(obj, con)\n",
    "    prob.solve(verbose = True)\n",
    "    if solSavePath is not None:\n",
    "        if not os.path.exists(solSavePath):\n",
    "            x.value[np.abs(x.value) < 1e-8] = 0\n",
    "            np.save(solSavePath, x.value)\n",
    "        else:\n",
    "            print(\"Optimal solution of cvxpy already exists!\\n\")\n",
    "    return x.value, prob.status\n",
    "from data.dataPreprocess import dataPreprocess"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [],
   "source": [
    "def constraint(x, Q, alpha, s, Dinv_half, b):\n",
    "    return 0.5 * x.T @ Q @ x - alpha * s @ (Dinv_half @ x) - b"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## econ-beaflw"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset = 'econ-beaflw'\n",
    "data = '../data/{}.npz'.format(dataset)\n",
    "alpha = 0.995\n",
    "b = -0.01\n",
    "Q, alpha, s, Dinv_half, D_half = dataPreprocess(data, alpha, random_seed = 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<502x502 sparse matrix of type '<class 'numpy.float64'>'\n",
       "\twith 90300 stored elements in Compressed Sparse Row format>"
      ]
     },
     "execution_count": 30,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "Q"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.4.1                                    \n",
      "===============================================================================\n",
      "(CVXPY) Apr 09 11:05:01 AM: Your problem has 502 variables, 0 constraints, and 0 parameters.\n",
      "(CVXPY) Apr 09 11:05:01 AM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) Apr 09 11:05:01 AM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) Apr 09 11:05:01 AM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "(CVXPY) Apr 09 11:05:01 AM: Your problem is compiled with the CPP canonicalization backend.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 09 11:05:01 AM: Compiling problem (target solver=OSQP).\n",
      "(CVXPY) Apr 09 11:05:01 AM: Reduction chain: CvxAttr2Constr -> Qp2SymbolicQp -> QpMatrixStuffing -> OSQP\n",
      "(CVXPY) Apr 09 11:05:01 AM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) Apr 09 11:05:01 AM: Applying reduction Qp2SymbolicQp\n",
      "(CVXPY) Apr 09 11:05:01 AM: Applying reduction QpMatrixStuffing\n",
      "(CVXPY) Apr 09 11:05:01 AM: Applying reduction OSQP\n",
      "(CVXPY) Apr 09 11:05:01 AM: Finished problem compilation (took 2.204e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 09 11:05:01 AM: Invoking solver OSQP  to obtain a solution.\n",
      "-----------------------------------------------------------------\n",
      "           OSQP v0.6.3  -  Operator Splitting QP Solver\n",
      "              (c) Bartolomeo Stellato,  Goran Banjac\n",
      "        University of Oxford  -  Stanford University 2021\n",
      "-----------------------------------------------------------------\n",
      "problem:  variables n = 502, constraints m = 0\n",
      "          nnz(P) + nnz(A) = 45401\n",
      "settings: linear system solver = qdldl,\n",
      "          eps_abs = 1.0e-05, eps_rel = 1.0e-05,\n",
      "          eps_prim_inf = 1.0e-04, eps_dual_inf = 1.0e-04,\n",
      "          rho = 1.00e-01 (adaptive),\n",
      "          sigma = 1.00e-06, alpha = 1.60, max_iter = 10000\n",
      "          check_termination: on (interval 25),\n",
      "          scaling: on, scaled_termination: off\n",
      "          warm start: on, polish: on, time_limit: off\n",
      "\n",
      "iter   objective    pri res    dua res    rho        time\n",
      "   1  -9.0637e-03   0.00e+00   3.53e-02   1.00e-01   1.37e-02s\n",
      "  25  -1.4162e-02   0.00e+00   1.67e-07   1.00e-01   1.95e-02s\n",
      "plsh  -1.4162e-02   0.00e+00   1.73e-17   --------   2.88e-02s\n",
      "\n",
      "status:               solved\n",
      "solution polish:      successful\n",
      "number of iterations: 25\n",
      "optimal objective:    -0.0142\n",
      "run time:             2.88e-02s\n",
      "optimal rho estimate: 1.00e-06\n",
      "\n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) Apr 09 11:05:01 AM: Problem status: optimal\n",
      "(CVXPY) Apr 09 11:05:01 AM: Optimal value: -1.416e-02\n",
      "(CVXPY) Apr 09 11:05:01 AM: Compilation took 2.204e-02 seconds\n",
      "(CVXPY) Apr 09 11:05:01 AM: Solver (including time spent in interface) took 3.257e-02 seconds\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "array([-1.27155268e-02, -3.07481248e-03, -6.57736346e-03, -1.69106845e-02,\n",
       "       -1.49619869e-02,  7.43552389e-03, -6.56974638e-03,  1.37985297e-03,\n",
       "        1.05949387e-03, -2.05008571e-03, -1.41393227e-03, -1.05691967e-02,\n",
       "       -8.15670884e-03, -1.03019018e-03, -3.30794090e-03, -1.96372497e-03,\n",
       "       -9.21930426e-03,  8.63355985e-04, -2.13875280e-03,  7.05452290e-03,\n",
       "        1.68668193e-02, -2.76063382e-03, -5.61611024e-03,  3.34929833e-03,\n",
       "       -1.37642033e-02,  8.67600069e-03, -3.02558661e-04,  1.14011750e-03,\n",
       "       -9.68234276e-03, -9.45685809e-03, -9.95674480e-04, -2.72444666e-03,\n",
       "        6.47846864e-03,  1.18164846e-02,  2.27727847e-03, -1.13444331e-03,\n",
       "       -7.48018381e-03, -9.44742432e-03,  2.31856615e-03,  1.87219228e-03,\n",
       "        6.50832188e-03,  9.47737765e-03,  1.60489875e-02, -1.28428081e-02,\n",
       "        3.75029067e-03,  5.34454298e-03,  1.18648741e-02, -5.29598386e-03,\n",
       "        1.31917298e-02,  1.57972242e-03,  6.81617099e-03, -3.37490699e-03,\n",
       "        5.47386026e-03,  1.54960009e-02,  1.93458375e-04, -3.11046334e-03,\n",
       "       -4.56279290e-04, -2.96604519e-03,  3.90449136e-03,  1.17391396e-03,\n",
       "        5.36323222e-03,  2.83724725e-03,  6.36122614e-03,  1.22989490e-02,\n",
       "       -1.48740725e-03,  3.31850129e-03,  1.94476547e-02, -3.40256614e-03,\n",
       "        6.41450108e-03, -5.19881404e-04, -5.19266878e-03, -9.89252772e-04,\n",
       "       -8.27701382e-03,  1.11017871e-02, -2.79030260e-03,  4.49472426e-03,\n",
       "        5.26684267e-03,  4.59284461e-03,  1.96253474e-03, -4.57848552e-04,\n",
       "        8.39827057e-03, -3.78081571e-03, -2.22887342e-03,  7.36119465e-03,\n",
       "       -1.17526961e-02, -1.55759285e-02, -8.49885771e-03,  1.18519136e-03,\n",
       "        8.33531059e-03, -6.01832151e-03,  3.15121728e-03, -8.95692051e-03,\n",
       "       -1.27308713e-03, -6.90544489e-03, -2.38924312e-03, -5.83565080e-03,\n",
       "       -6.98929950e-05, -1.09894469e-02, -9.51736661e-04, -3.06115549e-03,\n",
       "       -1.37404389e-02,  8.56398610e-03,  1.07742550e-02, -5.67809311e-03,\n",
       "        7.43101225e-03, -1.40676997e-02,  2.52586309e-03,  2.91521281e-03,\n",
       "       -1.41463822e-02, -1.38324395e-02, -1.44750699e-02, -9.79797145e-03,\n",
       "        4.60395536e-03, -6.60776486e-03,  1.69106707e-03, -5.15266816e-03,\n",
       "       -6.94027993e-03,  1.03157322e-03, -4.46396069e-03, -6.11265709e-03,\n",
       "       -2.94539331e-03,  6.92054356e-03, -3.41264032e-03, -1.08426450e-02,\n",
       "        3.89204776e-03,  5.80629625e-04,  2.81897620e-03, -2.01765645e-02,\n",
       "       -6.64570722e-03, -1.76869579e-03,  4.76579329e-03, -3.02664523e-03,\n",
       "        5.30119463e-03, -1.96714036e-04,  4.51438475e-03, -8.65442874e-03,\n",
       "       -4.22237391e-03,  1.71273160e-03, -1.97264438e-03,  1.00798991e-02,\n",
       "        9.98506829e-03, -2.50618866e-03, -1.20542098e-03, -6.10024622e-03,\n",
       "       -2.28855155e-02, -1.04980677e-02,  1.79187922e-02, -3.68955533e-02,\n",
       "        7.95447983e-03,  1.80848368e-03,  4.08493982e-04, -1.06965672e-02,\n",
       "        6.02533833e-03,  6.00483888e-03,  9.72121138e-04,  4.47302717e-03,\n",
       "       -1.28915459e-02,  6.60545368e-03,  6.51802128e-03,  1.73421775e-03,\n",
       "        3.10981695e-03, -1.50920576e-02, -6.07206742e-03, -6.68302020e-04,\n",
       "        6.58303534e-03, -6.48313205e-03,  7.04411648e-03,  1.31040007e-02,\n",
       "       -6.93715634e-03, -2.25655500e-03, -3.94124171e-03, -1.74167425e-03,\n",
       "       -5.64116661e-03,  5.55259602e-03,  8.67786465e-03, -4.81831744e-03,\n",
       "        5.20536263e-03,  5.05045178e-03,  4.02190576e-03, -1.23298654e-04,\n",
       "        2.46552313e-03,  9.54030721e-03,  4.18340679e-03,  1.96296573e-02,\n",
       "       -4.86721422e-03,  1.11565156e-02,  4.90488753e-03, -2.79849868e-04,\n",
       "        3.28346296e-03, -6.41287916e-03,  8.09569280e-03, -1.07431292e-03,\n",
       "        1.91326398e-04,  4.54198027e-03, -4.67536424e-03,  1.12217980e-03,\n",
       "       -3.84311107e-03, -2.83679107e-03, -1.70799205e-02, -6.23357741e-03,\n",
       "        1.91124667e-03,  1.69171674e-03, -4.74261590e-03, -2.57640135e-03,\n",
       "       -5.79101895e-03,  5.62886709e-03,  1.17885765e-04,  5.74604873e-03,\n",
       "       -1.76349700e-03,  8.41253261e-04, -8.18259917e-03, -3.00478707e-03,\n",
       "       -9.93588332e-03,  1.48381033e-03,  4.96333382e-03,  5.86643500e-03,\n",
       "        9.90490983e-05, -2.29168614e-03, -1.03624729e-02,  2.93849203e-04,\n",
       "        6.33662543e-03,  3.30023768e-03,  1.64910236e-03, -1.96275771e-03,\n",
       "        8.88379454e-03, -5.03694303e-04, -9.74070411e-04, -1.16273925e-03,\n",
       "        2.80235666e-03,  1.17843952e-03,  8.22943189e-03,  2.81423074e-03,\n",
       "        2.07194170e-03, -1.32062457e-03,  7.46818787e-03, -4.93289189e-03,\n",
       "       -5.30785201e-03,  1.83845997e-02, -4.37869727e-03, -2.48307360e-03,\n",
       "        1.96029360e-03,  1.76465132e-03,  9.86479351e-04,  2.90281053e-03,\n",
       "        2.40733261e-03,  1.66920959e-02, -1.38979078e-02, -6.58445165e-03,\n",
       "        7.75677376e-03,  9.02122815e-03, -3.71104828e-03,  2.10307093e-03,\n",
       "       -8.92582835e-04,  1.97146693e-03, -4.98303953e-03, -6.02587489e-03,\n",
       "        5.42753076e-03,  1.13656105e-02,  1.18920204e-02, -6.72125785e-03,\n",
       "        1.40306274e-02,  3.59732545e-03,  4.33368099e-03,  3.75433918e-04,\n",
       "        1.21981285e-02, -1.12923066e-03, -3.31898664e-03, -6.02641045e-04,\n",
       "        2.42188993e-03, -4.37995384e-04, -2.16006055e-03,  1.03701046e-02,\n",
       "       -1.07400977e-02, -2.38931263e-03,  5.62760551e-03,  2.71238010e-03,\n",
       "       -1.65358482e-03,  7.94709745e-04,  8.46099267e-03, -2.08808523e-02,\n",
       "        1.30384508e-03, -3.91089881e-03,  3.06894957e-03, -7.50776222e-03,\n",
       "       -1.51951866e-03, -3.40692995e-03,  6.97621909e-03, -7.84408682e-03,\n",
       "       -3.72756387e-03, -6.85633703e-03,  5.61198879e-03,  2.05659889e-03,\n",
       "       -9.75503877e-03,  5.20180646e-03,  5.64129270e-04, -5.57656049e-03,\n",
       "       -5.51289676e-04, -3.33351756e-03,  2.77198986e-03, -2.07351107e-03,\n",
       "        8.33151300e-03, -1.18114294e-02,  7.92109951e-04,  3.89265411e-03,\n",
       "       -3.31631742e-03,  2.58626179e-03,  5.86417287e-03,  6.38834585e-03,\n",
       "       -4.62908717e-03,  1.12864163e-03,  8.16225053e-04, -4.17767485e-03,\n",
       "        5.96074164e-03,  5.06761771e-03,  1.51340268e-03, -7.96941190e-04,\n",
       "        1.74244022e-04,  1.60244774e-03,  2.64022059e-04,  5.42973664e-04,\n",
       "        3.64666904e-03,  3.10579927e-03, -1.97768323e-03,  3.71033576e-03,\n",
       "        6.55327118e-03,  1.15768079e-03,  9.53672049e-04, -1.05397845e-02,\n",
       "        3.65666323e-03, -5.90515731e-03, -3.43068969e-03,  7.53476916e-03,\n",
       "       -5.05802702e-03,  8.21440089e-03,  1.49554843e-02, -4.11567781e-03,\n",
       "        1.11274888e-02, -2.51123392e-03,  3.89469138e-03, -6.34948882e-03,\n",
       "       -5.77467798e-03,  3.68600395e-03,  4.70411165e-03,  7.06807297e-03,\n",
       "        3.01374991e-03,  2.12386139e-03,  2.48504625e-03, -1.05369824e-03,\n",
       "       -2.70885570e-03, -1.45230772e-03,  3.61849208e-03,  7.47842393e-03,\n",
       "       -9.87398873e-03,  3.11958913e-03,  4.61268276e-03,  1.88438072e-03,\n",
       "        1.05701920e-02,  1.57878056e-03,  2.51580637e-03, -4.48924941e-03,\n",
       "       -5.24676129e-03, -3.16504441e-05, -5.49893433e-03, -2.77925598e-03,\n",
       "        1.31427817e-04, -7.07166209e-04,  1.64425848e-03,  2.28233467e-03,\n",
       "        1.58829822e-03,  6.00569168e-03, -1.29497631e-03,  4.25495735e-03,\n",
       "       -4.20650123e-03,  1.43554383e-03, -3.27649679e-04, -3.08190120e-03,\n",
       "       -4.12664704e-03,  1.08563584e-02,  1.47380223e-03, -4.52966073e-03,\n",
       "        1.28121117e-02, -3.52590822e-03,  1.44735456e-02,  4.75909451e-03,\n",
       "       -1.87390594e-04,  7.14711111e-03,  3.80673491e-03,  1.39388146e-02,\n",
       "       -1.01384625e-02, -7.23234496e-04, -3.68619924e-03,  1.13394130e-03,\n",
       "        1.55461458e-03,  8.56718022e-03,  2.54712216e-03,  5.74591935e-03,\n",
       "       -3.95522152e-03, -6.18054266e-03, -9.49968911e-03, -6.14496311e-03,\n",
       "        3.23700608e-03,  3.77981846e-03, -4.70176934e-03, -1.84487224e-03,\n",
       "        8.87578590e-03, -2.02820031e-03, -5.06930406e-03, -3.43289152e-04,\n",
       "        1.40255738e-03,  5.70937223e-03,  9.25439300e-03, -4.28647563e-03,\n",
       "        1.75953595e-03,  1.05397877e-03, -9.71816273e-03, -4.02784993e-03,\n",
       "       -1.50608798e-03, -1.17953560e-03, -7.38871726e-03, -1.16759451e-02,\n",
       "       -5.15228770e-03, -2.09382560e-03,  1.08716743e-02, -9.94759699e-04,\n",
       "        7.47919301e-04, -7.24243460e-04, -7.95546864e-03,  1.66615361e-02,\n",
       "        4.99670047e-03, -1.13033506e-03,  2.46428529e-03,  8.66652805e-03,\n",
       "       -4.42934028e-03, -1.24545399e-03,  8.72993572e-03, -3.40415631e-03,\n",
       "       -5.85278008e-03, -3.01962182e-05, -6.75267201e-03, -7.61556663e-04,\n",
       "        2.18092761e-03,  5.12394933e-03,  2.76558041e-04, -6.53608116e-04,\n",
       "       -2.80250482e-03,  3.87273876e-04, -1.43924201e-03,  4.90690801e-03,\n",
       "        5.24101978e-03,  3.69456794e-04,  2.69839510e-02, -2.69823997e-03,\n",
       "       -1.53805771e-03, -9.44722713e-04, -1.09531408e-03, -6.80070936e-03,\n",
       "        1.56177830e-03,  7.75324401e-03, -7.19295870e-04,  1.69851967e-04,\n",
       "        4.23033788e-03,  1.58399988e-02,  1.42088372e-03, -6.08360341e-04,\n",
       "        1.67219208e-03, -2.30020894e-02,  3.02896446e-03,  2.47106232e-03,\n",
       "        7.60531489e-03, -8.25010658e-04,  6.68328082e-03,  3.57652152e-03,\n",
       "        1.00533997e-03,  4.62603840e-03, -1.12292539e-02, -6.28469598e-03,\n",
       "       -5.29523713e-03,  2.96151118e-03, -8.29898602e-03, -4.69839148e-03,\n",
       "       -7.20916008e-03, -1.14404843e-02,  3.08523582e-03,  2.98975985e-03,\n",
       "       -3.68895645e-03,  9.80652305e-03, -6.16002102e-03, -1.69144367e-02,\n",
       "        1.65334394e-03, -1.26152536e-02,  5.89228641e-02,  1.02640899e-03,\n",
       "       -7.24136899e-03, -5.24842534e-03, -1.09897959e-02,  3.20995353e-04,\n",
       "        2.97848930e-03,  2.33311205e-03,  5.47793480e-03,  4.45384557e-04,\n",
       "       -2.26060336e-03,  2.04780164e-04])"
      ]
     },
     "execution_count": 31,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "xSlater, Slater_status = solve_slater_point(Q, alpha, s, Dinv_half, solSavePath = '../{}-Slater'.format(dataset))\n",
    "xSlater"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'optimal'"
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "Slater_status"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "-0.004161968505529108"
      ]
     },
     "execution_count": 33,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "constraint(xSlater, Q, alpha, s, Dinv_half, b)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [],
   "source": [
    "xOpt, Opt_status = solve_opt(Q, alpha, s, Dinv_half, b, D_half, solSavePath = '../cvxpySol/{}-Opt'.format(dataset))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([-7.53946928e-03,  0.00000000e+00, -1.02430401e-03, -1.19640410e-02,\n",
       "       -1.03054369e-02,  2.53435134e-03, -1.17161160e-03,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00, -5.43333639e-03,\n",
       "       -4.67547509e-03,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "       -3.17074370e-03,  0.00000000e+00,  0.00000000e+00,  2.53547502e-03,\n",
       "        1.12180891e-02,  0.00000000e+00, -9.81367380e-08,  0.00000000e+00,\n",
       "       -7.61250229e-03,  2.42003261e-03,  0.00000000e+00,  0.00000000e+00,\n",
       "       -3.77792875e-03, -3.66118615e-03,  0.00000000e+00,  0.00000000e+00,\n",
       "        1.36298049e-03,  5.56018034e-03,  0.00000000e+00,  0.00000000e+00,\n",
       "       -1.34627281e-03, -4.70069628e-03,  0.00000000e+00,  0.00000000e+00,\n",
       "        4.94760136e-04,  3.88564135e-03,  1.20815631e-02, -7.17724434e-03,\n",
       "        0.00000000e+00,  2.28467534e-03,  7.92389991e-03, -6.70024093e-08,\n",
       "        8.62576768e-03,  0.00000000e+00,  1.91377051e-03, -1.22889429e-08,\n",
       "        1.99240580e-03,  1.26531944e-02,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00, -1.36283018e-08,  0.00000000e+00,  0.00000000e+00,\n",
       "        6.82305422e-04,  0.00000000e+00,  1.59035194e-03,  7.06033031e-03,\n",
       "        0.00000000e+00,  0.00000000e+00,  1.63193758e-02,  0.00000000e+00,\n",
       "        1.13593270e-03,  0.00000000e+00, -6.80168088e-07,  0.00000000e+00,\n",
       "       -3.14301793e-03,  6.95078264e-03,  0.00000000e+00,  0.00000000e+00,\n",
       "        1.23275769e-08,  1.12227378e-07,  0.00000000e+00,  0.00000000e+00,\n",
       "        3.22206259e-03,  0.00000000e+00,  0.00000000e+00,  2.79586215e-08,\n",
       "       -7.02717586e-03, -1.10341950e-02, -3.32192049e-03,  0.00000000e+00,\n",
       "        3.54317080e-03, -2.24973302e-08,  0.00000000e+00, -3.86228985e-03,\n",
       "        0.00000000e+00, -1.62726462e-03,  0.00000000e+00, -1.31724985e-03,\n",
       "        0.00000000e+00, -4.92256322e-03,  0.00000000e+00,  0.00000000e+00,\n",
       "       -8.62549843e-03,  2.69605449e-03,  6.37551345e-03, -1.65171055e-08,\n",
       "        1.54512436e-03, -8.91118701e-03,  0.00000000e+00,  0.00000000e+00,\n",
       "       -9.07323481e-03, -9.83893198e-03, -9.65989942e-03, -6.34647425e-03,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00, -1.67961354e-08,\n",
       "       -1.84619353e-03,  0.00000000e+00, -1.68882678e-08, -4.83832754e-04,\n",
       "        0.00000000e+00,  9.98907249e-04, -1.51945111e-04, -6.27695729e-03,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00, -1.67566284e-02,\n",
       "       -2.87147843e-03,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        5.52653499e-04,  0.00000000e+00,  1.51339262e-08, -5.73774960e-03,\n",
       "       -1.27220926e-08,  0.00000000e+00,  0.00000000e+00,  6.03237946e-03,\n",
       "        4.41327848e-03,  0.00000000e+00,  0.00000000e+00, -2.21435657e-03,\n",
       "       -1.89994102e-02, -7.14113683e-03,  1.60160096e-02, -3.57660287e-02,\n",
       "        1.78529875e-03,  0.00000000e+00,  0.00000000e+00, -4.71923824e-03,\n",
       "        1.41392059e-03,  8.69382140e-04,  0.00000000e+00,  1.02904125e-08,\n",
       "       -9.63143592e-03,  5.04468948e-04,  4.42116186e-07,  0.00000000e+00,\n",
       "        0.00000000e+00, -1.03226125e-02, -2.39406863e-04,  0.00000000e+00,\n",
       "        3.23652616e-08, -1.62522721e-03,  1.74574199e-03,  8.70404080e-03,\n",
       "       -5.47878385e-04,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "       -2.18035500e-06,  1.17748898e-03,  4.23018940e-03, -2.48623882e-08,\n",
       "        2.08549970e-08,  7.44005357e-07,  5.71505199e-08,  0.00000000e+00,\n",
       "        0.00000000e+00,  4.16175221e-03,  0.00000000e+00,  1.54024926e-02,\n",
       "       -7.55362410e-05,  5.79829719e-03,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  2.13565780e-03,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00, -4.99663756e-04,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00, -1.23554428e-02,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "       -1.66651185e-03,  0.00000000e+00,  0.00000000e+00,  9.53629625e-04,\n",
       "        0.00000000e+00,  0.00000000e+00, -4.03238505e-03, -1.12890573e-08,\n",
       "       -6.98358952e-03,  0.00000000e+00,  0.00000000e+00,  3.25684967e-03,\n",
       "        0.00000000e+00,  0.00000000e+00, -2.23205419e-03,  0.00000000e+00,\n",
       "        7.07313528e-04,  1.82106364e-08,  0.00000000e+00,  0.00000000e+00,\n",
       "        2.41077143e-03,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  1.77347038e-03,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  1.68909233e-03, -1.14475419e-08,\n",
       "        0.00000000e+00,  1.41828972e-02, -7.47986161e-04,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00,  1.13178284e-08,\n",
       "        0.00000000e+00,  1.29452274e-02, -1.08049489e-02, -4.66850180e-04,\n",
       "        3.84302906e-03,  2.95525501e-03,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00, -6.17692915e-08, -1.72528995e-03,\n",
       "        4.39682667e-04,  6.82330230e-03,  6.92497184e-03, -3.33215250e-03,\n",
       "        1.08688489e-02,  0.00000000e+00,  1.39090165e-08,  0.00000000e+00,\n",
       "        6.27384573e-03,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00,  3.93481584e-04,\n",
       "       -3.94853310e-03,  0.00000000e+00,  1.30135946e-03,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  2.40065734e-08, -1.71915604e-02,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00, -9.92646435e-08,\n",
       "        0.00000000e+00,  0.00000000e+00,  1.38454139e-03, -2.08534851e-03,\n",
       "        0.00000000e+00, -5.24797215e-08,  1.43615306e-03,  0.00000000e+00,\n",
       "       -9.45942775e-04,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        2.47998798e-03, -6.57392893e-03,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "       -1.15013614e-08,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        1.02249919e-08,  3.92661001e-08,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        1.41738807e-06,  0.00000000e+00,  0.00000000e+00, -2.55386599e-03,\n",
       "        0.00000000e+00, -9.90086639e-07,  0.00000000e+00,  1.64733897e-03,\n",
       "       -1.77440795e-08,  2.83641860e-03,  8.31988415e-03,  0.00000000e+00,\n",
       "        5.24010945e-03,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  1.20460262e-08,  1.49137249e-08,  6.63026311e-04,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00,  3.04199355e-04,\n",
       "       -4.71886847e-03,  0.00000000e+00,  1.74834800e-08,  0.00000000e+00,\n",
       "        4.06541612e-03,  0.00000000e+00,  0.00000000e+00, -1.70090686e-08,\n",
       "       -2.80354356e-04,  0.00000000e+00, -1.37834588e-08,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  1.12265489e-08,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  5.45926663e-03,  0.00000000e+00,  0.00000000e+00,\n",
       "        7.86683289e-03, -1.96505079e-08,  8.65807259e-03,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00,  9.99836977e-03,\n",
       "       -4.07303929e-03,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  1.52849216e-03,  0.00000000e+00,  8.00110863e-04,\n",
       "        0.00000000e+00, -1.63885306e-08, -3.74061891e-03, -9.68696190e-04,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        1.43873237e-03,  0.00000000e+00, -1.20872396e-08,  0.00000000e+00,\n",
       "        0.00000000e+00,  4.31307659e-04,  3.42043071e-03,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00, -3.06869391e-03,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00, -4.16244632e-08, -6.18069045e-03,\n",
       "        0.00000000e+00,  0.00000000e+00,  3.68327042e-03,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00, -3.53199670e-03,  1.05263513e-02,\n",
       "        7.44729070e-04,  0.00000000e+00,  0.00000000e+00,  2.56528799e-03,\n",
       "        0.00000000e+00,  0.00000000e+00,  4.57944481e-03, -1.20860098e-06,\n",
       "       -6.15205469e-04,  0.00000000e+00, -2.32994746e-03,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        3.55477085e-08,  0.00000000e+00,  2.55248446e-02,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        3.48122483e-08,  1.35334136e-02,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00, -1.90899992e-02,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00, -5.45087110e-03, -3.78275874e-04,\n",
       "        0.00000000e+00,  0.00000000e+00, -3.22738349e-03, -7.57576894e-04,\n",
       "       -3.21461150e-03, -8.08379705e-03,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  4.03161520e-08,  0.00000000e+00, -1.56949329e-02,\n",
       "        6.22484971e-04, -1.19632181e-02,  5.82711301e-02,  0.00000000e+00,\n",
       "       -1.57613736e-03,  0.00000000e+00, -1.83712746e-03,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00])"
      ]
     },
     "execution_count": 35,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "xOpt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'optimal'"
      ]
     },
     "execution_count": 36,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "Opt_status"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([  0,   2,   3,   4,   5,   6,  11,  12,  16,  19,  20,  22,  24,\n",
       "         25,  28,  29,  32,  33,  36,  37,  40,  41,  42,  43,  45,  46,\n",
       "         47,  48,  50,  51,  52,  53,  57,  60,  62,  63,  66,  68,  70,\n",
       "         72,  73,  76,  77,  80,  83,  84,  85,  86,  88,  89,  91,  93,\n",
       "         95,  97, 100, 101, 102, 103, 104, 105, 108, 109, 110, 111, 115,\n",
       "        116, 118, 119, 121, 122, 123, 127, 128, 132, 134, 135, 136, 139,\n",
       "        140, 143, 144, 145, 146, 147, 148, 151, 152, 153, 155, 156, 157,\n",
       "        158, 161, 162, 164, 165, 166, 167, 168, 172, 173, 174, 175, 176,\n",
       "        177, 178, 181, 183, 184, 185, 190, 194, 198, 204, 207, 210, 211,\n",
       "        212, 215, 218, 220, 221, 224, 230, 234, 235, 237, 238, 243, 245,\n",
       "        246, 247, 248, 249, 254, 255, 256, 257, 258, 259, 260, 262, 264,\n",
       "        271, 272, 274, 278, 279, 283, 286, 287, 289, 290, 292, 300, 301,\n",
       "        308, 312, 313, 324, 327, 329, 331, 332, 333, 334, 336, 341, 342,\n",
       "        343, 351, 352, 354, 356, 359, 360, 362, 369, 377, 380, 381, 382,\n",
       "        387, 388, 393, 395, 397, 398, 399, 404, 406, 409, 410, 414, 418,\n",
       "        419, 422, 426, 427, 428, 431, 434, 435, 436, 438, 448, 450, 460,\n",
       "        461, 465, 474, 475, 478, 479, 480, 481, 485, 487, 488, 489, 490,\n",
       "        492, 494]),)"
      ]
     },
     "execution_count": 37,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "xOpt[abs(xOpt) < 1e-08] = 0\n",
    "np.nonzero(xOpt)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "223"
      ]
     },
     "execution_count": 38,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.count_nonzero(xOpt)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "502"
      ]
     },
     "execution_count": 39,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(xOpt)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "apdpro",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.12"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
