{
 "cells": [
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## choose proper b for running"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import os,sys\n",
    "sys.path.append(\"..\")\n",
    "from  preSolve import solve_slater_point, solve_opt\n",
    "from data.dataPreprocess import dataPreprocess"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "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": [
    "## dd68"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "data = '../data/DD68.npz'\n",
    "alpha = 0.4\n",
    "b = -0.005\n",
    "Q, alpha, s, Dinv_half, D_half = dataPreprocess(data, alpha, random_seed = 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<775x775 sparse matrix of type '<class 'numpy.float64'>'\n",
       "\twith 4961 stored elements in Compressed Sparse Row format>"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "Q"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([-8.53991970e-03, -6.34445436e-03, -7.56648846e-03, -1.36307135e-02,\n",
       "       -1.17872471e-02,  3.37487521e-03, -2.98544437e-03,  1.54012402e-03,\n",
       "        7.61750112e-04, -1.56328851e-03, -3.94619428e-04, -5.56589986e-03,\n",
       "       -2.77530601e-03, -1.63906334e-03, -2.61506198e-03, -1.08974197e-03,\n",
       "       -6.64700959e-03,  3.72956454e-04, -1.92781381e-03,  3.42936673e-03,\n",
       "        1.03969438e-02, -1.02777502e-03, -5.37474696e-03,  3.82986383e-03,\n",
       "       -1.06370470e-02,  1.05049162e-02,  6.35953719e-04,  1.11516078e-03,\n",
       "       -7.67339177e-03, -7.55399328e-03, -1.08631883e-03, -1.12277710e-03,\n",
       "        5.52087862e-03,  8.55577459e-03,  1.78019451e-03,  9.56119555e-04,\n",
       "       -4.12519709e-03, -4.74639733e-03,  2.18305405e-03,  2.17266285e-03,\n",
       "        6.17879252e-03,  6.20891372e-03,  8.87519806e-03, -7.26380827e-03,\n",
       "        2.42332857e-03,  2.83560150e-03,  5.18163065e-03, -3.31833012e-03,\n",
       "        8.67014800e-03,  1.72539838e-03,  5.06786039e-03, -4.06255486e-04,\n",
       "        3.69943669e-03,  6.89816633e-03,  5.60150276e-04, -1.74005741e-03,\n",
       "        5.29514563e-04, -2.42027740e-04,  4.76641352e-03,  4.32425712e-03,\n",
       "        4.53746308e-03,  3.15205699e-03,  4.49254648e-03,  7.37643401e-03,\n",
       "        8.48464153e-04,  2.85562330e-03,  7.42477870e-03,  1.31873520e-05,\n",
       "        3.85602855e-03,  7.92257456e-04, -3.28446906e-03,  5.79614849e-04,\n",
       "       -6.10321796e-03,  4.31677706e-03, -1.77871090e-03,  4.00396614e-03,\n",
       "        5.47601089e-03,  3.20147166e-03,  2.25129562e-03,  6.34128157e-04,\n",
       "        5.76233607e-03, -4.14981520e-03, -4.96605881e-03,  7.83494132e-03,\n",
       "       -9.61011196e-03, -1.26332660e-02, -9.26431588e-03, -2.46988049e-03,\n",
       "        7.33339010e-03, -4.66105531e-03, -1.26554546e-03, -8.75391902e-03,\n",
       "       -2.67399321e-03, -7.72763243e-03, -3.69430882e-03, -4.97752885e-03,\n",
       "       -1.69238063e-03, -9.16722640e-03, -5.01183490e-04, -2.21981736e-03,\n",
       "       -8.92329897e-03,  5.90148807e-03,  2.97868586e-03, -5.02142252e-03,\n",
       "        7.77486977e-03, -1.23155381e-02, -9.00254607e-04,  1.94356981e-03,\n",
       "       -1.12231264e-02, -9.84183310e-03, -1.23007855e-02, -6.38026094e-03,\n",
       "        3.49540530e-03, -8.62726810e-03,  1.02048263e-03, -4.57946755e-03,\n",
       "       -3.87448549e-03, -6.59331969e-04, -4.09462356e-03, -5.05809271e-03,\n",
       "       -2.53617321e-03,  4.31058344e-03, -1.09681473e-03, -5.25830566e-03,\n",
       "        8.65238748e-04,  6.81298419e-04,  1.09179532e-03, -7.89560858e-03,\n",
       "       -4.68752092e-03, -4.91731056e-03,  2.91935832e-03, -2.45220950e-03,\n",
       "        3.30456282e-03, -1.44485164e-04,  3.98641968e-03, -1.84933332e-03,\n",
       "       -2.91644978e-03,  6.44472759e-04,  1.42196686e-04,  6.60907041e-03,\n",
       "        6.56891824e-03, -5.09686063e-03, -3.69133773e-03, -6.01537368e-03,\n",
       "       -1.18541928e-02, -6.17841979e-03,  4.58888056e-03, -2.92184623e-03,\n",
       "        6.68335668e-03,  3.12310854e-03,  1.53249003e-03, -5.90582858e-03,\n",
       "        4.65565834e-03,  4.71430664e-03, -2.41749317e-04,  2.28470813e-03,\n",
       "       -3.62505204e-03,  6.19519109e-03,  3.18238261e-03,  2.71536446e-03,\n",
       "        1.46246760e-03, -1.18862214e-02, -6.17709880e-03, -3.54257440e-03,\n",
       "        3.52105811e-03, -5.15663209e-03,  3.44565295e-03,  6.03960186e-03,\n",
       "       -6.38359084e-03, -3.61201897e-04, -6.00499055e-03, -2.31523235e-03,\n",
       "       -4.54428391e-03,  3.29640728e-03,  5.88060544e-03, -1.14157406e-03,\n",
       "        6.67359050e-03,  4.88700160e-03,  1.80198428e-03,  1.85831498e-03,\n",
       "        2.50312405e-03,  7.98807344e-03,  3.89827507e-03,  9.76795073e-03,\n",
       "       -6.87492619e-04,  8.75322195e-03,  4.29542102e-03,  1.61463795e-03,\n",
       "        5.23493447e-03, -7.62127225e-03,  7.31427878e-03, -1.17536910e-03,\n",
       "        1.52805617e-03,  6.33256525e-03, -2.59759597e-03,  9.61319738e-04,\n",
       "       -2.89253564e-03, -2.32473176e-03, -8.51797252e-03, -5.29891445e-03,\n",
       "        6.75164404e-04,  2.35754717e-03, -5.35288586e-03, -2.43269507e-05,\n",
       "       -1.21476587e-03,  7.19373443e-03, -5.17546526e-04,  2.27133198e-03,\n",
       "       -1.66454958e-03,  3.72410451e-04, -3.37101674e-03, -1.95516007e-03,\n",
       "       -2.49166360e-03,  3.98128383e-03,  5.11561629e-03,  4.08974545e-03,\n",
       "       -5.34905072e-04, -2.20445652e-03, -9.81741385e-03, -2.79583902e-04,\n",
       "        4.11669550e-03,  2.06854073e-03,  4.83331069e-03, -3.54424752e-04,\n",
       "        8.54249359e-03, -9.85828138e-04,  1.42990725e-03, -8.31872760e-04,\n",
       "        4.91529819e-03,  2.39766804e-03,  7.48644670e-03,  4.33193431e-03,\n",
       "        4.09134848e-03, -2.60401713e-03,  4.37610923e-03, -4.83145095e-03,\n",
       "       -9.70229177e-03,  1.27776402e-02, -4.73934549e-03, -2.51648789e-03,\n",
       "        3.11472711e-03,  2.28209882e-03,  1.40406452e-03,  2.80382832e-03,\n",
       "        4.44613969e-04,  7.07420205e-03, -4.72473789e-03, -3.38488777e-03,\n",
       "        3.68263546e-03,  7.78162891e-03, -3.46836295e-04,  2.81401826e-03,\n",
       "        7.54611616e-04,  3.11122515e-03, -1.97417981e-03, -3.61546825e-04,\n",
       "        5.14780174e-03,  8.80546849e-03,  8.04122735e-03, -8.44145158e-04,\n",
       "        6.16153029e-03,  2.64197503e-03,  4.94176985e-03,  3.51687900e-04,\n",
       "        1.05899814e-02,  8.47825274e-04, -2.94417794e-03, -1.72447317e-03,\n",
       "        2.97705467e-03, -2.37744343e-04, -4.38879299e-04,  1.29495996e-02,\n",
       "       -9.88173748e-03, -1.43514945e-03,  3.49794786e-03,  1.87228210e-03,\n",
       "       -2.73228376e-03, -1.13059533e-03,  6.31775218e-03, -1.08563732e-02,\n",
       "       -1.32800818e-03, -2.55768796e-03,  4.50304316e-03, -1.21637869e-02,\n",
       "       -1.44131233e-03, -4.15495688e-03,  3.46792245e-03, -5.55233419e-03,\n",
       "       -1.96133020e-03, -5.30766812e-03,  4.50558450e-03,  3.84116857e-03,\n",
       "       -1.10957296e-02,  4.35067475e-03, -1.67685938e-03, -7.74115834e-03,\n",
       "       -5.62651612e-04, -3.32597185e-03,  2.81103182e-03, -1.36661676e-03,\n",
       "        5.02602575e-03, -6.77650964e-03,  1.73849911e-04,  2.42737005e-03,\n",
       "       -4.61450558e-03,  3.21056613e-03,  6.05309969e-03,  5.26119353e-03,\n",
       "       -3.15911304e-03,  4.86038998e-04,  1.00787437e-03, -4.08877105e-03,\n",
       "        5.95799496e-03,  2.93415719e-03,  3.13689881e-04,  4.70075827e-04,\n",
       "        1.28063887e-03,  2.43769901e-03,  1.17329887e-03,  7.52797044e-04,\n",
       "        3.67707800e-03,  2.63409765e-03, -3.31834389e-04,  4.67860158e-03,\n",
       "        4.58707734e-03, -2.69687238e-04, -3.24796149e-03, -1.60283427e-02,\n",
       "        3.13530169e-03, -4.71027086e-03, -1.48426948e-03,  5.51678928e-03,\n",
       "       -4.50589922e-03,  6.28296446e-03,  1.34698176e-02, -3.29330002e-03,\n",
       "        1.08416331e-02, -4.29642052e-03,  1.23875418e-03, -8.56241469e-03,\n",
       "       -5.54420294e-03,  3.48168150e-03,  3.99456114e-03,  5.65636861e-03,\n",
       "        1.16446229e-03,  5.96826039e-04,  8.46842891e-04, -2.72225948e-03,\n",
       "       -2.56654605e-03, -1.46035676e-03,  3.07469304e-03,  8.41674868e-03,\n",
       "       -8.10097834e-03,  6.55048519e-03,  6.34854364e-03,  5.30271360e-03,\n",
       "        1.22082833e-02,  4.66350920e-03,  4.41270895e-03, -3.40772155e-03,\n",
       "       -1.83747960e-03, -1.23455022e-03, -6.22273661e-03, -1.24523795e-03,\n",
       "        4.28551560e-04, -5.08746504e-04,  8.51141316e-04,  1.69195221e-03,\n",
       "        4.13003786e-03,  5.80599713e-03, -1.57548242e-03,  3.75607339e-03,\n",
       "       -4.14292356e-03,  8.61914018e-04, -6.90428366e-04, -2.28393567e-03,\n",
       "       -2.91220557e-03,  7.92642811e-03,  2.39474275e-03, -3.85512799e-03,\n",
       "        8.40383028e-03,  1.21157791e-03,  1.12818166e-02,  5.69982360e-03,\n",
       "        2.75947016e-04,  7.66641367e-03,  6.01470798e-03,  4.65285487e-03,\n",
       "       -6.37546145e-03, -1.46621945e-03, -1.55501497e-03,  9.55616172e-04,\n",
       "        1.63437384e-03,  9.40491897e-03,  1.63209622e-03,  2.33490603e-03,\n",
       "       -4.74746048e-03, -5.59675394e-03, -4.98858971e-03, -4.97640520e-03,\n",
       "        4.17766965e-03,  6.18136708e-03, -4.12859166e-03, -2.08963783e-03,\n",
       "        1.06174529e-02, -2.95160787e-04, -2.85457465e-03,  1.44828298e-05,\n",
       "        1.16455710e-04,  4.22166198e-03,  8.19164922e-03, -3.39515472e-03,\n",
       "        3.32040880e-03,  4.70223370e-04, -1.07753704e-02, -5.44411204e-03,\n",
       "       -3.50458134e-03, -7.45600888e-04, -7.26098525e-03, -9.66782756e-03,\n",
       "       -3.56890393e-03, -2.07837124e-03,  9.45120459e-03, -6.27961244e-04,\n",
       "        1.40479258e-03, -1.96994219e-04, -6.94632918e-03,  1.25951191e-02,\n",
       "        4.70879570e-03, -2.22870152e-03,  4.26444562e-03,  1.02353100e-02,\n",
       "       -3.10659384e-03, -2.07203198e-03,  2.21967009e-03, -2.01654184e-03,\n",
       "       -4.85733080e-03,  6.09598955e-04, -1.93436393e-03,  1.76680597e-03,\n",
       "        4.79058786e-03,  9.32545301e-03, -6.23442878e-04, -1.79324020e-03,\n",
       "       -4.94900963e-03,  1.27451875e-03, -2.95918965e-03,  4.02855769e-03,\n",
       "        3.02662161e-03,  3.03458062e-03,  6.42795823e-03, -4.67587115e-04,\n",
       "       -2.44767623e-03, -1.30652736e-03, -1.77638924e-03, -1.28958973e-02,\n",
       "        9.21301753e-04,  1.15084576e-02,  1.21311624e-03,  1.55322229e-03,\n",
       "        3.64705493e-03,  3.07320431e-03,  1.39823478e-03,  1.48745393e-03,\n",
       "        4.47383429e-03, -1.86354976e-02,  2.53318354e-03,  6.35544584e-03,\n",
       "        1.09014859e-02,  1.00594807e-03,  1.03894779e-02,  4.41983158e-03,\n",
       "        2.41314121e-03,  3.53779877e-03, -9.69975141e-03, -6.46910886e-03,\n",
       "       -6.60558326e-03,  3.90160102e-03, -4.81492319e-03, -2.42544786e-03,\n",
       "       -3.55668547e-03, -5.95174293e-03,  6.20340657e-03,  1.90315836e-03,\n",
       "       -5.23334594e-03,  1.22990040e-02, -6.35765701e-03, -1.21826181e-03,\n",
       "        2.53566787e-04,  3.51641954e-04,  7.88198548e-03,  3.62006127e-03,\n",
       "       -7.41801792e-03, -8.97611186e-03, -1.33401671e-02,  1.64865709e-03,\n",
       "        4.62551696e-03,  4.67087927e-03,  5.58142708e-03,  9.93011900e-04,\n",
       "       -9.90772265e-04,  6.80838971e-04, -7.21754974e-03, -6.83055289e-04,\n",
       "        3.72334524e-03,  4.86253450e-03,  8.92401951e-03,  8.93607641e-03,\n",
       "        4.62421328e-03, -9.36301988e-03, -4.82639302e-03, -5.60204257e-03,\n",
       "        6.29247006e-03,  1.02704818e-02,  6.01651175e-03, -7.17669605e-04,\n",
       "       -5.78968067e-03, -6.04179418e-03, -2.95114874e-03, -1.35102422e-02,\n",
       "        2.28365527e-03,  5.62221597e-03,  8.94993454e-03,  5.82939271e-03,\n",
       "       -1.59950126e-03,  4.49152941e-03, -8.32738805e-03, -6.06128458e-03,\n",
       "        1.17259909e-02, -2.58944524e-03,  9.41858153e-03, -1.00028475e-04,\n",
       "       -5.96034058e-03,  1.14326781e-03,  1.14868683e-02,  6.48478622e-03,\n",
       "       -8.40680810e-06,  3.14962403e-03,  2.76918328e-03,  8.94830506e-04,\n",
       "       -1.62342190e-03,  7.02340314e-03,  1.25888962e-03, -7.19334466e-03,\n",
       "        3.09203344e-03,  4.91004457e-03, -5.43990178e-03,  1.10214186e-02,\n",
       "       -6.28500267e-03,  3.51722913e-03, -3.48423452e-04, -1.13147957e-03,\n",
       "       -3.38969981e-03,  4.71513006e-03,  3.94744687e-03, -4.61455552e-03,\n",
       "        1.00065099e-02, -7.20366394e-05,  7.24096223e-03,  4.16695021e-03,\n",
       "       -7.57822300e-03,  6.04949645e-04, -6.15501076e-04,  9.01265770e-03,\n",
       "        4.00274653e-03, -2.44408495e-04, -2.42155136e-03, -1.35817073e-03,\n",
       "       -5.24685060e-04, -7.07266045e-03,  1.33224649e-03,  1.18662635e-02,\n",
       "        1.07552535e-03, -3.92034233e-03, -1.38599165e-03,  1.92172317e-03,\n",
       "        5.54713050e-03,  6.83009867e-03,  1.96285668e-03, -3.29306969e-03,\n",
       "        1.04560708e-02,  7.03869279e-03,  5.03146691e-03, -3.21975129e-03,\n",
       "        4.35082294e-03,  7.33779542e-03,  1.01677945e-03, -3.08390643e-03,\n",
       "        3.03313655e-03,  1.47935481e-02, -1.94686169e-03, -1.36809841e-03,\n",
       "        1.62286628e-03,  8.96132760e-03, -3.25291186e-03, -4.04832065e-03,\n",
       "       -1.01270863e-03,  3.38860757e-04,  3.32567426e-03,  2.21692015e-04,\n",
       "        7.02054094e-03, -2.36726125e-03,  5.47878241e-03, -1.30969526e-04,\n",
       "        6.09505233e-03,  3.39486564e-03,  1.57776232e-03,  9.40096660e-03,\n",
       "        1.53966554e-03,  3.70593271e-03,  1.00907569e-02,  4.92568682e-03,\n",
       "       -4.45069593e-03, -6.06281210e-03, -2.87198881e-03, -1.34320656e-03,\n",
       "       -1.67131300e-03,  3.11917585e-04, -5.30830908e-03,  7.06931599e-03,\n",
       "       -3.85203458e-03,  2.63485815e-03,  8.65766190e-04,  2.54490396e-03,\n",
       "        1.56975967e-03,  7.70910269e-03, -1.18851951e-04, -7.05238739e-03,\n",
       "        2.35666465e-03, -2.51361773e-04,  5.21205333e-03,  2.90203866e-04,\n",
       "       -2.64439309e-03,  5.75777795e-04,  1.61047726e-03, -1.16675156e-03,\n",
       "        6.91597994e-03, -2.82850786e-03, -3.68025262e-03, -6.97175009e-03,\n",
       "        2.14183552e-07, -1.42797721e-02, -9.29395240e-03,  3.76511512e-03,\n",
       "        5.64920339e-03,  1.17094529e-03, -5.94492963e-03, -8.67582206e-04,\n",
       "        3.01537238e-03, -5.06941057e-03,  9.75973236e-04,  1.14172003e-02,\n",
       "       -6.83107346e-04, -2.20662561e-03, -9.25502057e-04, -2.23411232e-03,\n",
       "        3.22678073e-04,  7.82455818e-03,  3.92232227e-03,  6.29704820e-03,\n",
       "        5.81655559e-03,  4.21190482e-03, -4.88578455e-04,  1.28704903e-03,\n",
       "        2.87351172e-03,  3.62216925e-03, -1.84092146e-03, -5.95597513e-03,\n",
       "        1.06118564e-02,  3.10690723e-04,  5.06984613e-03,  1.03812060e-02,\n",
       "        9.86641182e-03,  6.59328514e-03,  1.29113056e-03,  7.48359416e-04,\n",
       "        7.73593105e-03, -6.91497799e-03, -9.62327369e-03, -3.85673461e-03,\n",
       "        3.16744986e-03, -8.79381596e-03, -9.46565129e-03, -3.49270065e-03,\n",
       "        3.92801135e-03,  2.28927763e-02, -7.04272970e-03,  6.53004864e-03,\n",
       "        7.90109892e-04, -1.23288260e-02, -1.58821756e-03, -3.10039113e-03,\n",
       "        7.13263318e-03,  8.80417514e-03,  2.78905063e-03, -7.45527695e-03,\n",
       "        1.35496171e-03,  4.28574202e-03, -2.80424655e-03, -9.07625804e-03,\n",
       "        7.30509122e-03,  7.07250997e-03,  5.34192453e-03, -7.37176640e-03,\n",
       "        8.53200068e-04, -1.16587322e-02, -6.82704132e-03,  1.59630977e-03,\n",
       "       -5.71991328e-03, -4.88902485e-04,  4.93082837e-03, -4.92174808e-03,\n",
       "        2.35173478e-03,  2.90332745e-03, -7.63682896e-03,  1.90139588e-03,\n",
       "        5.77012261e-03,  1.55750950e-03, -9.38931733e-03,  2.60156869e-03,\n",
       "        3.04937168e-03,  3.68589602e-03, -2.32799951e-03,  2.63141942e-03,\n",
       "        9.84394815e-03,  1.13856938e-02,  7.83622931e-03, -6.54732753e-03,\n",
       "       -3.97473955e-03, -5.30549588e-03,  4.63936972e-03,  5.23356944e-03,\n",
       "        4.28374026e-03,  1.05605668e-02, -1.19308794e-02,  2.04311915e-02,\n",
       "       -8.45146048e-04,  8.09134029e-03,  2.30377830e-03,  6.30306457e-03,\n",
       "        9.93835226e-03,  7.11798248e-03, -7.19818396e-03,  1.17325561e-03,\n",
       "        2.23872599e-03, -5.10851961e-03, -5.35528432e-04, -4.05552763e-03,\n",
       "        9.05759990e-03, -2.11159832e-03, -1.90002985e-03,  1.05621282e-02,\n",
       "       -8.38863298e-04, -8.47688785e-03, -1.08285569e-03, -4.54604427e-03,\n",
       "       -3.15976945e-03,  5.20488818e-03,  3.35263596e-04,  6.63127309e-03,\n",
       "        1.90945592e-03, -2.21988290e-03, -4.54002781e-03, -1.95281499e-05,\n",
       "       -4.86910514e-03,  4.85406468e-03,  1.22921186e-03,  1.09823509e-03,\n",
       "       -8.63561398e-03,  1.83121229e-03,  3.99647691e-03,  1.07683033e-03,\n",
       "        4.99726271e-03, -4.12138566e-04, -3.24032137e-04])"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "xSlater, Slater_status = solve_slater_point(Q, alpha, s, Dinv_half, solSavePath = '../slaterPoint/DD68-Slater')\n",
    "xSlater"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'optimal'"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "Slater_status"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "-0.0023849082190951516"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "constraint(xSlater, Q, alpha, s, Dinv_half, b)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Intel MKL WARNING: Support of Intel(R) Streaming SIMD Extensions 4.2 (Intel(R) SSE4.2) enabled only processors has been deprecated. Intel oneAPI Math Kernel Library 2025.0 will require Intel(R) Advanced Vector Extensions (Intel(R) AVX) instructions.\n",
      "Intel MKL WARNING: Support of Intel(R) Streaming SIMD Extensions 4.2 (Intel(R) SSE4.2) enabled only processors has been deprecated. Intel oneAPI Math Kernel Library 2025.0 will require Intel(R) Advanced Vector Extensions (Intel(R) AVX) instructions.\n",
      "Intel MKL WARNING: Support of Intel(R) Streaming SIMD Extensions 4.2 (Intel(R) SSE4.2) enabled only processors has been deprecated. Intel oneAPI Math Kernel Library 2025.0 will require Intel(R) Advanced Vector Extensions (Intel(R) AVX) instructions.\n",
      "Intel MKL WARNING: Support of Intel(R) Streaming SIMD Extensions 4.2 (Intel(R) SSE4.2) enabled only processors has been deprecated. Intel oneAPI Math Kernel Library 2025.0 will require Intel(R) Advanced Vector Extensions (Intel(R) AVX) instructions.\n",
      "Intel MKL WARNING: Support of Intel(R) Streaming SIMD Extensions 4.2 (Intel(R) SSE4.2) enabled only processors has been deprecated. Intel oneAPI Math Kernel Library 2025.0 will require Intel(R) Advanced Vector Extensions (Intel(R) AVX) instructions.\n",
      "Intel MKL WARNING: Support of Intel(R) Streaming SIMD Extensions 4.2 (Intel(R) SSE4.2) enabled only processors has been deprecated. Intel oneAPI Math Kernel Library 2025.0 will require Intel(R) Advanced Vector Extensions (Intel(R) AVX) instructions.\n",
      "Intel MKL WARNING: Support of Intel(R) Streaming SIMD Extensions 4.2 (Intel(R) SSE4.2) enabled only processors has been deprecated. Intel oneAPI Math Kernel Library 2025.0 will require Intel(R) Advanced Vector Extensions (Intel(R) AVX) instructions.\n",
      "Intel MKL WARNING: Support of Intel(R) Streaming SIMD Extensions 4.2 (Intel(R) SSE4.2) enabled only processors has been deprecated. Intel oneAPI Math Kernel Library 2025.0 will require Intel(R) Advanced Vector Extensions (Intel(R) AVX) instructions.\n",
      "Intel MKL WARNING: Support of Intel(R) Streaming SIMD Extensions 4.2 (Intel(R) SSE4.2) enabled only processors has been deprecated. Intel oneAPI Math Kernel Library 2025.0 will require Intel(R) Advanced Vector Extensions (Intel(R) AVX) instructions.\n",
      "Intel MKL WARNING: Support of Intel(R) Streaming SIMD Extensions 4.2 (Intel(R) SSE4.2) enabled only processors has been deprecated. Intel oneAPI Math Kernel Library 2025.0 will require Intel(R) Advanced Vector Extensions (Intel(R) AVX) instructions.\n",
      "Intel MKL WARNING: Support of Intel(R) Streaming SIMD Extensions 4.2 (Intel(R) SSE4.2) enabled only processors has been deprecated. Intel oneAPI Math Kernel Library 2025.0 will require Intel(R) Advanced Vector Extensions (Intel(R) AVX) instructions.\n",
      "Intel MKL WARNING: Support of Intel(R) Streaming SIMD Extensions 4.2 (Intel(R) SSE4.2) enabled only processors has been deprecated. Intel oneAPI Math Kernel Library 2025.0 will require Intel(R) Advanced Vector Extensions (Intel(R) AVX) instructions.\n",
      "Intel MKL WARNING: Support of Intel(R) Streaming SIMD Extensions 4.2 (Intel(R) SSE4.2) enabled only processors has been deprecated. Intel oneAPI Math Kernel Library 2025.0 will require Intel(R) Advanced Vector Extensions (Intel(R) AVX) instructions.\n",
      "Intel MKL WARNING: Support of Intel(R) Streaming SIMD Extensions 4.2 (Intel(R) SSE4.2) enabled only processors has been deprecated. Intel oneAPI Math Kernel Library 2025.0 will require Intel(R) Advanced Vector Extensions (Intel(R) AVX) instructions.\n",
      "Intel MKL WARNING: Support of Intel(R) Streaming SIMD Extensions 4.2 (Intel(R) SSE4.2) enabled only processors has been deprecated. Intel oneAPI Math Kernel Library 2025.0 will require Intel(R) Advanced Vector Extensions (Intel(R) AVX) instructions.\n",
      "Intel MKL WARNING: Support of Intel(R) Streaming SIMD Extensions 4.2 (Intel(R) SSE4.2) enabled only processors has been deprecated. Intel oneAPI Math Kernel Library 2025.0 will require Intel(R) Advanced Vector Extensions (Intel(R) AVX) instructions.\n",
      "Intel MKL WARNING: Support of Intel(R) Streaming SIMD Extensions 4.2 (Intel(R) SSE4.2) enabled only processors has been deprecated. Intel oneAPI Math Kernel Library 2025.0 will require Intel(R) Advanced Vector Extensions (Intel(R) AVX) instructions.\n",
      "Intel MKL WARNING: Support of Intel(R) Streaming SIMD Extensions 4.2 (Intel(R) SSE4.2) enabled only processors has been deprecated. Intel oneAPI Math Kernel Library 2025.0 will require Intel(R) Advanced Vector Extensions (Intel(R) AVX) instructions.\n",
      "Intel MKL WARNING: Support of Intel(R) Streaming SIMD Extensions 4.2 (Intel(R) SSE4.2) enabled only processors has been deprecated. Intel oneAPI Math Kernel Library 2025.0 will require Intel(R) Advanced Vector Extensions (Intel(R) AVX) instructions.\n",
      "Intel MKL WARNING: Support of Intel(R) Streaming SIMD Extensions 4.2 (Intel(R) SSE4.2) enabled only processors has been deprecated. Intel oneAPI Math Kernel Library 2025.0 will require Intel(R) Advanced Vector Extensions (Intel(R) AVX) instructions.\n",
      "Intel MKL WARNING: Support of Intel(R) Streaming SIMD Extensions 4.2 (Intel(R) SSE4.2) enabled only processors has been deprecated. Intel oneAPI Math Kernel Library 2025.0 will require Intel(R) Advanced Vector Extensions (Intel(R) AVX) instructions.\n",
      "Intel MKL WARNING: Support of Intel(R) Streaming SIMD Extensions 4.2 (Intel(R) SSE4.2) enabled only processors has been deprecated. Intel oneAPI Math Kernel Library 2025.0 will require Intel(R) Advanced Vector Extensions (Intel(R) AVX) instructions.\n",
      "Intel MKL WARNING: Support of Intel(R) Streaming SIMD Extensions 4.2 (Intel(R) SSE4.2) enabled only processors has been deprecated. Intel oneAPI Math Kernel Library 2025.0 will require Intel(R) Advanced Vector Extensions (Intel(R) AVX) instructions.\n"
     ]
    }
   ],
   "source": [
    "xOpt, Opt_status = solve_opt(Q, alpha, s, Dinv_half, b, D_half, solSavePath = '../cvxpySol/DD68-Opt')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([-5.23694753e-03, -1.29890382e-03, -1.92310452e-03, -8.45384467e-03,\n",
       "       -7.26450208e-03,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00, -9.14182865e-04,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "       -2.76153149e-03,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        3.97968803e-03,  0.00000000e+00, -2.16539380e-03,  7.59584085e-04,\n",
       "       -7.46168861e-03,  6.84354527e-03,  0.00000000e+00,  0.00000000e+00,\n",
       "       -3.92922037e-03, -3.66787650e-03,  0.00000000e+00,  0.00000000e+00,\n",
       "        2.89041739e-03,  4.86579761e-03,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00, -1.10552090e-03,  0.00000000e+00,  0.00000000e+00,\n",
       "        1.93210984e-03,  8.43781122e-04,  4.12669287e-03, -4.25017670e-03,\n",
       "        0.00000000e+00,  0.00000000e+00,  1.37563893e-03,  0.00000000e+00,\n",
       "        5.27725261e-03,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  2.20431018e-03,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  2.67521854e-04,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00,  1.59069132e-03,\n",
       "        0.00000000e+00,  0.00000000e+00,  1.86319603e-03,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "       -2.38775371e-03,  2.46961368e-04,  0.00000000e+00,  0.00000000e+00,\n",
       "        4.12971890e-04,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        5.64232046e-04, -1.24697568e-03,  0.00000000e+00,  5.57699470e-03,\n",
       "       -5.32295235e-03, -6.64790194e-03, -4.41052262e-03,  0.00000000e+00,\n",
       "        5.60552840e-03, -2.50647827e-03,  0.00000000e+00, -4.16395419e-03,\n",
       "        0.00000000e+00, -3.92434804e-03,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00, -4.34913656e-03,  0.00000000e+00,  0.00000000e+00,\n",
       "       -5.49997995e-03,  1.99799344e-03,  4.22011019e-04, -3.85771362e-04,\n",
       "        4.33704211e-03, -7.58865633e-03,  0.00000000e+00,  0.00000000e+00,\n",
       "       -5.59973859e-03, -5.15070986e-03, -8.22338387e-03, -4.53718640e-03,\n",
       "        1.29863402e-03, -5.28278870e-03,  0.00000000e+00,  0.00000000e+00,\n",
       "       -7.25523379e-05,  0.00000000e+00,  0.00000000e+00, -7.35467223e-05,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00, -5.60026827e-04,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00, -3.19728061e-03,\n",
       "       -9.64525691e-04, -1.51418351e-03,  0.00000000e+00, -5.53832294e-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.75289024e-03,\n",
       "        2.99490610e-03, -6.55305864e-04,  0.00000000e+00, -8.89606168e-04,\n",
       "       -5.81845072e-03, -7.52858707e-04,  0.00000000e+00,  0.00000000e+00,\n",
       "        1.96232013e-03,  0.00000000e+00,  0.00000000e+00, -3.58855667e-03,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "       -9.10738120e-04,  2.14295899e-03,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00, -7.77325558e-03, -2.55643057e-03,  0.00000000e+00,\n",
       "        8.35827265e-04, -1.76765774e-03,  0.00000000e+00,  1.89195795e-03,\n",
       "       -3.29947796e-03,  0.00000000e+00, -1.49489304e-03,  0.00000000e+00,\n",
       "       -7.41362022e-04,  0.00000000e+00,  6.95094597e-04,  0.00000000e+00,\n",
       "        3.96699478e-03,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  4.00607236e-03,  0.00000000e+00,  4.09066137e-03,\n",
       "        0.00000000e+00,  3.49892696e-03,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00, -4.94973657e-03,  1.85892419e-03,  0.00000000e+00,\n",
       "        0.00000000e+00,  2.39015641e-03, -2.68738204e-04,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00, -3.89662799e-03, -8.08173125e-04,\n",
       "        0.00000000e+00,  0.00000000e+00, -2.62842454e-03,  0.00000000e+00,\n",
       "        0.00000000e+00,  2.41437865e-03,  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",
       "        0.00000000e+00,  0.00000000e+00, -6.19406609e-03,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        3.13318771e-03,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  2.19113071e-03,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  6.53282965e-04, -1.18530518e-03,\n",
       "       -7.10738169e-03,  1.13982278e-02, -1.22125300e-03,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  2.70038091e-03,  0.00000000e+00, -6.21269258e-05,\n",
       "        0.00000000e+00,  2.98145678e-03,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  4.99712935e-03,  1.07299486e-03,  0.00000000e+00,\n",
       "        2.09875245e-03,  0.00000000e+00,  4.22257048e-04,  0.00000000e+00,\n",
       "        5.70262568e-03,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00,  8.52610677e-03,\n",
       "       -7.22335921e-03,  0.00000000e+00,  3.38833333e-04,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  4.07545774e-03, -4.60936771e-03,\n",
       "        0.00000000e+00,  0.00000000e+00,  1.32729881e-03, -9.66166114e-03,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00, -2.52493259e-03,\n",
       "        0.00000000e+00, -1.99136993e-03,  0.00000000e+00,  0.00000000e+00,\n",
       "       -7.72385680e-03,  0.00000000e+00,  0.00000000e+00, -4.42577414e-03,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        3.76112715e-04, -2.60841954e-03,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00,  1.06421122e-04,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        1.21456151e-03,  0.00000000e+00,  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,  7.29458747e-04,\n",
       "        1.38499458e-04,  0.00000000e+00,  0.00000000e+00, -1.22011175e-02,\n",
       "        2.57747323e-04, -2.24365844e-03,  0.00000000e+00,  1.75632823e-03,\n",
       "       -1.56089955e-03,  3.28665994e-03,  9.50773010e-03, -7.57490009e-04,\n",
       "        6.93123894e-03, -7.23823280e-04,  0.00000000e+00, -4.31675460e-03,\n",
       "       -1.55281814e-03,  0.00000000e+00,  0.00000000e+00,  1.40547066e-03,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  1.57782604e-04,  3.61847079e-03,\n",
       "       -5.86860352e-03,  7.68423669e-04,  4.72144584e-04,  9.80634121e-04,\n",
       "        7.19578858e-03,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00, -3.15362404e-03,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  3.38762297e-04,  0.00000000e+00,  5.14433042e-04,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "       -1.77433102e-05,  4.33477863e-03,  0.00000000e+00, -5.05856190e-04,\n",
       "        4.00701814e-03,  0.00000000e+00,  5.59323113e-03,  0.00000000e+00,\n",
       "        0.00000000e+00,  3.57687979e-03,  2.50977778e-03,  0.00000000e+00,\n",
       "       -2.02231597e-03,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  4.37946723e-03,  0.00000000e+00,  0.00000000e+00,\n",
       "       -8.93313839e-04, -1.49839420e-03, -2.14254836e-03, -1.64319483e-03,\n",
       "        3.72576314e-04,  3.84842309e-03, -2.53864529e-03,  0.00000000e+00,\n",
       "        5.88850537e-03,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  6.12764789e-04,  5.57749826e-03, -4.84475490e-04,\n",
       "        1.02910112e-03,  0.00000000e+00, -4.55806196e-03,  0.00000000e+00,\n",
       "       -6.74657726e-04,  0.00000000e+00, -2.87755633e-03, -6.22970776e-03,\n",
       "        0.00000000e+00,  0.00000000e+00,  2.55098185e-03,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00, -3.76605446e-03,  6.12663422e-03,\n",
       "        3.74537330e-04,  0.00000000e+00,  0.00000000e+00,  5.73587964e-03,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "       -8.38469726e-04,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        4.96597537e-04,  4.45257461e-03,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00,  2.20315995e-03,\n",
       "        2.48617498e-04,  0.00000000e+00,  2.57658121e-03,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00, -1.00345106e-02,\n",
       "        0.00000000e+00,  7.22031757e-03,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  3.13128365e-06,  0.00000000e+00,  0.00000000e+00,\n",
       "        1.17192956e-03, -1.61826668e-02,  1.33244304e-03,  1.28446861e-03,\n",
       "        6.22480173e-03,  0.00000000e+00,  5.25465151e-03,  7.77990219e-04,\n",
       "        0.00000000e+00,  2.32120507e-03, -6.05813071e-03, -1.23889086e-03,\n",
       "       -1.75793273e-03,  1.09796579e-03,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00, -2.72794488e-03,  0.00000000e+00,  0.00000000e+00,\n",
       "       -2.06763763e-03,  7.98143896e-03, -2.35494881e-03,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  2.49038442e-03,  0.00000000e+00,\n",
       "       -6.02776963e-04, -2.73815742e-03, -7.45805932e-03,  0.00000000e+00,\n",
       "        1.42583440e-05,  7.19438016e-05,  2.37558376e-03,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00, -3.18624166e-03,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  2.26946826e-03,  3.26154975e-03,\n",
       "        2.07633329e-03, -7.52165271e-03, -9.86327605e-04, -2.22722625e-03,\n",
       "        2.52637014e-03,  6.27399217e-03,  3.71797085e-04,  0.00000000e+00,\n",
       "       -7.84085870e-04, -1.60072716e-03,  0.00000000e+00, -8.95818689e-03,\n",
       "        0.00000000e+00,  6.51010535e-04,  3.32408153e-03,  2.23784506e-04,\n",
       "        0.00000000e+00,  3.19856804e-03, -5.79734179e-03, -2.51524639e-03,\n",
       "        8.19820816e-03,  0.00000000e+00,  6.73943712e-03,  0.00000000e+00,\n",
       "       -3.08262613e-03,  0.00000000e+00,  8.54479133e-03,  4.09464197e-03,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  3.30107071e-03,  0.00000000e+00, -4.55321641e-03,\n",
       "        0.00000000e+00,  1.48632504e-03, -1.36140209e-03,  7.43267188e-03,\n",
       "       -1.46539855e-03,  1.21694339e-03,  0.00000000e+00,  0.00000000e+00,\n",
       "       -5.32085913e-05,  1.26952789e-03,  0.00000000e+00, -1.41549910e-03,\n",
       "        6.43571696e-03,  0.00000000e+00,  3.89920270e-03,  2.40044196e-04,\n",
       "       -3.84828174e-03,  0.00000000e+00,  0.00000000e+00,  5.40216728e-03,\n",
       "        7.87906271e-04,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00, -3.38686550e-03,  0.00000000e+00,  8.96781718e-03,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        1.83328806e-03,  3.35897850e-03,  0.00000000e+00, -4.40356947e-04,\n",
       "        6.19689859e-03,  4.47259031e-03,  9.61822589e-04, -1.86064731e-03,\n",
       "        0.00000000e+00,  2.12756276e-03,  0.00000000e+00, -1.18544642e-03,\n",
       "        0.00000000e+00,  1.02913738e-02,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  5.19150689e-03,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        4.73789584e-03,  0.00000000e+00,  1.12713669e-03,  0.00000000e+00,\n",
       "        2.67195718e-03,  0.00000000e+00,  0.00000000e+00,  4.70355240e-03,\n",
       "        0.00000000e+00,  0.00000000e+00,  4.04468824e-03,  3.09867361e-03,\n",
       "       -1.04924563e-03, -2.66136196e-03,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00, -2.12539847e-03,  4.80247852e-03,\n",
       "       -4.54306410e-04,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  3.69391890e-03,  0.00000000e+00, -4.19359526e-03,\n",
       "        0.00000000e+00,  0.00000000e+00,  1.79952285e-03,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        1.76169779e-03,  0.00000000e+00, -5.20510269e-04, -3.02077018e-03,\n",
       "        0.00000000e+00, -1.05919385e-02, -5.63023004e-03,  2.33037650e-03,\n",
       "        8.03718868e-04,  0.00000000e+00, -2.48410623e-03,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00,  7.80580635e-03,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  3.04350438e-03,  0.00000000e+00,  1.35636565e-03,\n",
       "        5.87851446e-04,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        0.00000000e+00,  0.00000000e+00,  0.00000000e+00, -2.85392124e-03,\n",
       "        6.41321508e-03,  0.00000000e+00,  2.18971004e-04,  5.19492487e-03,\n",
       "        5.95259205e-03,  2.27276649e-03,  0.00000000e+00,  0.00000000e+00,\n",
       "        5.02029785e-03, -3.65691283e-03, -5.17594262e-03, -1.14898797e-03,\n",
       "        2.04235203e-03, -6.46102407e-03, -5.86365957e-03, -4.66221484e-04,\n",
       "        0.00000000e+00,  1.99399938e-02, -1.94493425e-03,  1.69052161e-03,\n",
       "        0.00000000e+00, -7.28022286e-03,  0.00000000e+00, -3.96713363e-04,\n",
       "        1.96013154e-03,  5.51621838e-03,  0.00000000e+00, -3.61783950e-03,\n",
       "        1.98220097e-04,  0.00000000e+00, -1.45928525e-04, -6.16223062e-03,\n",
       "        4.02722517e-03,  3.43313616e-03,  8.55287735e-05, -4.41354055e-03,\n",
       "        0.00000000e+00, -6.14370992e-03,  0.00000000e+00,  0.00000000e+00,\n",
       "       -4.13559937e-03,  0.00000000e+00,  1.68551503e-03, -1.69268351e-03,\n",
       "        0.00000000e+00,  0.00000000e+00, -4.15757322e-03,  0.00000000e+00,\n",
       "        3.96491043e-03,  0.00000000e+00, -6.90595605e-03,  0.00000000e+00,\n",
       "        0.00000000e+00,  4.50862013e-04,  0.00000000e+00,  0.00000000e+00,\n",
       "        7.17569188e-03,  6.87259082e-03,  5.03237297e-03, -5.33057447e-03,\n",
       "       -1.96065693e-03, -1.45426651e-03,  7.07010850e-04,  2.01215128e-03,\n",
       "        1.77097796e-03,  6.88021607e-03, -9.84987456e-03,  1.66604797e-02,\n",
       "        0.00000000e+00,  5.36248084e-03,  0.00000000e+00,  1.74483841e-03,\n",
       "        7.56295792e-03,  3.83231573e-03, -4.31682141e-03,  0.00000000e+00,\n",
       "        1.46469628e-04, -2.56912407e-03,  0.00000000e+00, -1.39663938e-03,\n",
       "        7.23951354e-03,  0.00000000e+00, -4.36701543e-05,  6.25531706e-03,\n",
       "        0.00000000e+00, -5.63681181e-03,  0.00000000e+00, -2.42445054e-03,\n",
       "       -1.21206108e-03,  1.78881034e-03,  0.00000000e+00,  4.48503624e-03,\n",
       "        0.00000000e+00,  0.00000000e+00, -1.80083683e-03,  0.00000000e+00,\n",
       "       -1.04980924e-03,  4.40529624e-04,  0.00000000e+00,  0.00000000e+00,\n",
       "       -6.47387875e-03,  0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
       "        2.63839603e-03,  0.00000000e+00,  0.00000000e+00])"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "xOpt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'optimal'"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "Opt_status"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([  0,   1,   2,   3,   4,  11,  16,  20,  22,  23,  24,  25,  28,\n",
       "         29,  32,  33,  37,  40,  41,  42,  43,  46,  48,  53,  58,  63,\n",
       "         66,  72,  73,  76,  80,  81,  83,  84,  85,  86,  88,  89,  91,\n",
       "         93,  97, 100, 101, 102, 103, 104, 105, 108, 109, 110, 111, 112,\n",
       "        113, 116, 119, 123, 127, 128, 129, 131, 139, 140, 141, 143, 144,\n",
       "        145, 148, 151, 156, 157, 161, 162, 164, 165, 167, 168, 170, 172,\n",
       "        174, 176, 181, 183, 185, 189, 190, 193, 194, 198, 199, 202, 205,\n",
       "        218, 224, 230, 234, 235, 236, 237, 238, 245, 247, 249, 257, 258,\n",
       "        260, 262, 264, 271, 272, 274, 278, 279, 282, 283, 287, 289, 292,\n",
       "        295, 300, 301, 307, 312, 323, 324, 327, 328, 329, 331, 332, 333,\n",
       "        334, 335, 336, 337, 339, 340, 343, 350, 351, 352, 353, 354, 355,\n",
       "        356, 362, 369, 371, 376, 377, 379, 380, 382, 385, 386, 388, 393,\n",
       "        396, 397, 398, 399, 400, 401, 402, 404, 409, 410, 411, 412, 414,\n",
       "        416, 418, 419, 422, 426, 427, 428, 431, 436, 440, 441, 447, 448,\n",
       "        450, 455, 457, 461, 464, 465, 466, 467, 468, 470, 471, 473, 474,\n",
       "        475, 476, 477, 481, 484, 485, 486, 490, 492, 493, 494, 496, 497,\n",
       "        498, 502, 506, 507, 508, 509, 510, 511, 512, 513, 514, 516, 517,\n",
       "        519, 521, 522, 523, 525, 526, 527, 528, 530, 532, 534, 535, 541,\n",
       "        543, 545, 546, 547, 548, 549, 552, 553, 555, 556, 558, 559, 560,\n",
       "        563, 564, 569, 571, 576, 577, 579, 580, 581, 582, 583, 585, 587,\n",
       "        589, 593, 600, 602, 604, 607, 610, 611, 612, 613, 618, 619, 620,\n",
       "        625, 627, 630, 636, 638, 639, 641, 642, 643, 644, 646, 651, 657,\n",
       "        659, 660, 667, 668, 670, 671, 672, 673, 676, 677, 678, 679, 680,\n",
       "        681, 682, 683, 685, 686, 687, 689, 691, 692, 693, 695, 696, 698,\n",
       "        699, 700, 701, 702, 703, 705, 708, 710, 711, 714, 716, 718, 721,\n",
       "        724, 725, 726, 727, 728, 729, 730, 731, 732, 733, 734, 735, 737,\n",
       "        739, 740, 741, 742, 744, 745, 747, 748, 750, 751, 753, 755, 756,\n",
       "        757, 759, 762, 764, 765, 768, 772]),)"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "xOpt[abs(xOpt) < 1e-08] = 0\n",
    "np.nonzero(xOpt)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "358"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.count_nonzero(xOpt)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "775"
      ]
     },
     "execution_count": 23,
     "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.11.3"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
