{
 "cells": [
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## choose proper b for running"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "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": 15,
   "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": [
    "### bio-DM-LC"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "data = '../data/bio-DM-LC.npz'\n",
    "alpha = 0.4\n",
    "b = -0.02\n",
    "Q, alpha, s, Dinv_half, D_half = dataPreprocess(data, alpha, random_seed = 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<658x658 sparse matrix of type '<class 'numpy.float64'>'\n",
       "\twith 2916 stored elements in Compressed Sparse Row format>"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "Q"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([-2.89701658e-02, -1.08880186e-02, -1.93877017e-02, -3.74068272e-02,\n",
       "       -2.42381636e-02,  9.42419554e-03, -4.35361064e-03,  1.02603873e-03,\n",
       "        6.95836540e-04,  3.11196752e-03,  1.34979726e-04,  7.44429987e-05,\n",
       "       -2.15063275e-03,  1.29341456e-03,  2.18220116e-03, -5.84780658e-04,\n",
       "       -4.71322500e-03,  1.86826763e-03,  1.42854255e-03,  2.93875040e-03,\n",
       "        6.43502725e-03,  1.22310842e-03, -5.54435411e-03,  3.89594101e-05,\n",
       "       -6.97517722e-03,  8.65584487e-03, -7.17037830e-04,  2.11922148e-03,\n",
       "       -3.85493983e-02, -3.79033696e-02,  3.70223761e-03,  7.75898568e-03,\n",
       "        1.19970225e-02,  2.27075765e-02,  3.02815150e-03, -1.71422607e-03,\n",
       "       -5.64303584e-03, -5.51459673e-03,  1.80086109e-03,  1.40960024e-03,\n",
       "        4.84366898e-03,  6.55306380e-03,  7.87032963e-03, -8.95853778e-03,\n",
       "        2.36377377e-03,  2.03438913e-03,  5.78354465e-03, -3.55935478e-03,\n",
       "        7.44525374e-03,  1.81011667e-03,  4.76713689e-03, -5.66079032e-03,\n",
       "        1.27060969e-02,  1.73994487e-02, -5.60721510e-04, -4.63639020e-03,\n",
       "       -1.12835946e-03, -3.34130855e-03, -4.28456583e-04,  3.50364155e-03,\n",
       "        9.04236787e-03,  3.84577029e-03,  7.34815724e-03,  1.74262436e-02,\n",
       "       -1.29449756e-03,  6.85083252e-03,  1.68759073e-02, -1.31807655e-03,\n",
       "        1.26381714e-02, -1.71709133e-03, -3.68646199e-03, -2.39732447e-03,\n",
       "       -8.43889685e-03,  1.54118891e-02, -6.46393829e-03,  6.91812079e-03,\n",
       "        4.30706114e-03,  4.40490890e-03,  2.81693562e-03, -3.35394930e-04,\n",
       "        1.94299336e-03, -9.64833081e-03, -5.59678789e-03,  7.76994123e-03,\n",
       "       -1.93024894e-02, -1.44417493e-02, -1.96386533e-02, -5.79828848e-03,\n",
       "        5.48703001e-03, -8.64471910e-03,  6.82708590e-03, -5.00411026e-03,\n",
       "       -5.37432107e-04,  5.44784883e-04, -4.22583538e-03, -1.06434640e-02,\n",
       "       -3.11317618e-03, -1.61646914e-02, -3.01156129e-03, -3.84340877e-03,\n",
       "       -2.61238598e-02,  7.90114128e-03,  1.34684286e-02, -7.92483185e-03,\n",
       "        1.08417170e-02, -1.97959468e-02,  2.35130152e-04,  1.78085725e-03,\n",
       "       -2.80745823e-02, -2.30634388e-02, -1.44335877e-02, -5.63776053e-03,\n",
       "        4.39136896e-03, -1.09126539e-02,  4.93528356e-04, -2.15416545e-02,\n",
       "       -2.30166063e-02, -3.87456952e-03, -9.76638552e-03, -1.42502729e-02,\n",
       "       -4.20652889e-03,  4.19487306e-03, -3.99890921e-03, -9.57141235e-03,\n",
       "        2.12451377e-03,  2.53849491e-03,  1.19125213e-03, -1.52050260e-02,\n",
       "       -1.20871839e-02, -3.32788730e-03,  3.29117501e-03, -1.01510966e-02,\n",
       "        2.72332789e-03, -1.47188479e-03,  2.49468472e-03, -8.56363417e-03,\n",
       "       -9.06750858e-03, -4.99478150e-03, -1.05691190e-03,  1.07825645e-02,\n",
       "        1.14814169e-02, -3.74613071e-03, -4.15315464e-03, -9.01432202e-03,\n",
       "       -2.71891418e-02, -1.33831195e-02,  7.33889849e-03, -7.75008223e-03,\n",
       "        2.69937875e-03,  5.08882944e-03,  8.97746522e-04, -7.70377523e-04,\n",
       "        6.39247961e-03,  8.24634940e-03,  2.80250423e-03,  3.44749324e-03,\n",
       "       -7.48766070e-03,  1.82524622e-02,  1.18404195e-02,  4.69823314e-03,\n",
       "        1.96658865e-03, -1.43830463e-02, -4.23425986e-03,  7.66391275e-04,\n",
       "        1.06243861e-02, -6.10191261e-03,  3.21080544e-03,  7.24862930e-03,\n",
       "       -8.78182302e-03,  4.20403252e-03, -6.83305471e-03, -5.70623001e-03,\n",
       "       -1.38805773e-02,  9.43935572e-03,  8.91958783e-03, -6.80986751e-03,\n",
       "        1.95047291e-03,  5.95607833e-03,  4.89101172e-03, -1.33395138e-04,\n",
       "        9.67078840e-03,  1.54621326e-02,  1.26696549e-02,  3.36240811e-02,\n",
       "        6.62090454e-03,  2.83914402e-02,  2.05232971e-02,  5.78181068e-04,\n",
       "        1.12795370e-02, -1.14855666e-02,  9.24202672e-03, -2.78439261e-03,\n",
       "       -8.22514116e-03,  1.61673034e-02, -8.44561876e-03,  1.66548800e-03,\n",
       "       -1.06091614e-02, -5.47132037e-03, -3.23104068e-02, -2.02801013e-02,\n",
       "        4.54149200e-03,  2.26225132e-03, -1.68331786e-02, -1.03663027e-02,\n",
       "       -1.01460979e-02,  2.48099080e-02,  1.63385984e-03,  8.17135583e-03,\n",
       "       -3.08859880e-04,  3.56599721e-03, -1.00863950e-02, -6.77754927e-03,\n",
       "       -1.36040631e-02,  6.69204978e-03,  1.99686696e-02,  1.45250695e-02,\n",
       "       -1.04475560e-03, -4.26482683e-03, -3.99522253e-02, -1.65074536e-02,\n",
       "        9.16638059e-03,  7.30283899e-03,  3.71784762e-03, -4.71183889e-03,\n",
       "        1.60477131e-02, -1.06721452e-03, -1.66292740e-03, -4.75467124e-03,\n",
       "        1.34332027e-03,  9.07440168e-03,  2.34729806e-02,  5.76951608e-03,\n",
       "        6.44643722e-03, -1.03071808e-03,  1.25723792e-02, -1.06144639e-02,\n",
       "       -1.42937061e-02,  1.20202996e-02, -5.44936445e-03, -2.47895434e-03,\n",
       "        1.31155079e-02,  2.57764441e-03,  2.42772529e-03,  5.98083144e-03,\n",
       "        7.68768145e-03,  2.60366704e-02, -1.51214392e-02, -1.09159998e-02,\n",
       "        1.11891557e-02,  7.53675168e-03, -3.90783896e-03,  2.98013551e-03,\n",
       "       -1.81520334e-03,  4.19774035e-03, -9.70682393e-03,  2.59732035e-04,\n",
       "        8.61483922e-03,  1.28430181e-02,  2.35934580e-02, -2.22421283e-03,\n",
       "        9.45345676e-03,  6.70118437e-03,  8.77047844e-03,  3.17539993e-03,\n",
       "        2.25585402e-02,  2.45477961e-04, -3.96140434e-03,  6.06331121e-03,\n",
       "        4.57663704e-03, -8.09108551e-04,  2.15562129e-03,  4.22667907e-02,\n",
       "       -2.79041143e-02, -5.11822052e-03,  1.29726013e-02,  1.62339877e-02,\n",
       "       -6.94986899e-03,  7.05427103e-04,  1.20796708e-02, -1.22491804e-02,\n",
       "        6.72376457e-04, -6.04502674e-03,  4.12703774e-03, -9.11172145e-03,\n",
       "       -1.68545555e-03, -3.60138188e-03,  6.22536832e-03, -7.17956697e-03,\n",
       "       -4.08243856e-03, -7.71840803e-03,  3.74704711e-03,  2.87338248e-03,\n",
       "       -3.30093660e-02,  9.35132983e-03, -4.21791971e-04, -1.35191499e-02,\n",
       "       -3.27149501e-04, -1.00336007e-02,  3.18019528e-03, -6.93549902e-03,\n",
       "        1.59085051e-02, -1.25452880e-02,  6.23774079e-03,  1.49093335e-02,\n",
       "       -1.28014012e-02,  9.35239931e-03,  1.64808789e-02,  1.94133197e-02,\n",
       "       -6.07815583e-04,  2.13792651e-03,  1.21651625e-03, -5.10381927e-03,\n",
       "        1.72985023e-02,  1.11672377e-02,  2.15963178e-03, -1.35975457e-03,\n",
       "        3.09295832e-05,  5.58494537e-03,  3.29033920e-03,  2.24364687e-03,\n",
       "        6.74492211e-03,  3.79334025e-03, -2.24761502e-03,  9.74451276e-03,\n",
       "        1.20301600e-02,  5.81773679e-03,  2.53568852e-03, -1.93081869e-02,\n",
       "        9.26806500e-03, -1.34850794e-02, -1.06318220e-02,  9.02632974e-03,\n",
       "       -4.95094467e-03,  4.14198115e-02,  5.64477852e-02, -2.03718631e-03,\n",
       "        1.24035151e-02, -7.01304179e-03,  1.93098886e-03, -3.77468415e-02,\n",
       "       -3.17262320e-02,  1.33371440e-02,  1.57253739e-02,  2.50110526e-02,\n",
       "        1.71353557e-02,  5.96849503e-03,  6.23253949e-03,  1.57322021e-04,\n",
       "       -3.29828540e-03, -1.37542772e-03,  7.98230141e-03,  1.08369446e-02,\n",
       "       -8.79891640e-03,  5.39198321e-03,  4.32634088e-03,  3.47312996e-03,\n",
       "        1.37857603e-02,  3.85328332e-03,  3.20283495e-03, -4.13821616e-03,\n",
       "       -4.46418243e-03,  5.67521456e-05, -6.40462750e-03, -2.13115856e-03,\n",
       "        4.89633346e-04, -7.95388462e-04,  1.32204263e-03,  9.00100825e-03,\n",
       "        1.82367027e-03,  8.58297483e-03, -2.96002786e-03,  7.60152764e-03,\n",
       "       -5.39594233e-03,  2.19059809e-03, -2.40814746e-04, -3.13253767e-03,\n",
       "       -4.30524594e-03,  1.18034339e-02,  1.88096731e-03, -5.64680579e-03,\n",
       "        1.27309998e-02, -2.43908209e-03,  3.27277994e-02,  1.79323573e-02,\n",
       "        7.12314184e-03,  3.07984067e-02,  2.20751709e-02,  1.15040895e-02,\n",
       "       -2.04974950e-02, -2.74237142e-03, -9.81419344e-03,  2.23582661e-03,\n",
       "        3.97843172e-03,  2.37897204e-02,  1.63858845e-03,  9.32529208e-03,\n",
       "       -8.19461651e-03, -1.78512605e-02, -7.12077590e-03, -1.17651326e-02,\n",
       "        2.11603500e-03,  1.51250323e-02, -4.50043544e-03, -5.07397901e-03,\n",
       "        2.75483528e-02,  6.65288290e-04, -1.49700360e-02, -7.27321850e-03,\n",
       "        2.80372826e-03,  1.17105877e-02,  2.28875224e-02, -1.19047489e-02,\n",
       "       -6.03782900e-04,  7.99851770e-03, -1.75869219e-02, -1.06900191e-02,\n",
       "       -6.84237419e-03, -4.77190650e-03, -2.90204035e-02, -2.78914543e-02,\n",
       "       -2.04275605e-02, -3.41335824e-03,  3.17497745e-02, -1.41113953e-03,\n",
       "        8.58311140e-03, -1.45301308e-03, -7.77196146e-03,  2.40519047e-02,\n",
       "        7.80752627e-03,  1.89320411e-03,  7.75842906e-03,  1.63104994e-02,\n",
       "       -1.42170118e-02, -7.28213579e-04,  1.49060266e-02,  1.80705786e-03,\n",
       "       -9.31056217e-03, -3.24734620e-03, -9.53484244e-03, -4.31614385e-03,\n",
       "        6.01808535e-03,  1.71386474e-02,  1.51715876e-03, -2.56067377e-03,\n",
       "       -1.24784830e-02,  1.94173991e-03, -6.38965096e-03,  6.55279954e-03,\n",
       "        1.26687320e-02,  2.16483326e-03,  1.98652284e-02, -8.93829906e-03,\n",
       "       -7.00768298e-03, -7.12435569e-03, -7.99469062e-03, -3.37187549e-02,\n",
       "        1.33723296e-02,  2.64690413e-02, -2.35506499e-03,  2.54409721e-03,\n",
       "        6.70530660e-03,  1.12643183e-02,  4.95230056e-03, -4.36655966e-03,\n",
       "       -1.20628841e-03, -3.54046527e-02,  1.36788396e-02,  1.16624551e-02,\n",
       "        2.43482897e-02, -2.24558582e-03,  2.69992109e-02,  1.17225433e-02,\n",
       "        9.03552164e-03,  3.91648190e-03, -1.40842391e-02, -6.61960831e-03,\n",
       "       -1.34275370e-02,  2.78032767e-03, -1.14668779e-02, -9.17243905e-03,\n",
       "       -1.40052154e-02, -1.43017819e-02,  3.16715012e-03,  3.02359817e-03,\n",
       "       -8.46224419e-03,  3.99932112e-02, -7.74334462e-03, -8.72613538e-03,\n",
       "        1.26618774e-04, -3.88576460e-03,  7.93097832e-03,  8.82659235e-03,\n",
       "       -1.46629257e-02, -1.93803433e-02, -4.09843743e-02, -8.16086467e-03,\n",
       "        4.50449676e-03,  5.03908616e-03,  8.30815861e-03,  2.72531353e-03,\n",
       "       -6.29866281e-03,  7.38086888e-04, -7.43898524e-03,  1.11355450e-02,\n",
       "        4.56467516e-03,  7.72953745e-03,  2.08014811e-02,  1.40338812e-02,\n",
       "        8.83887326e-03, -3.00392530e-02, -2.59018479e-02, -1.31634442e-02,\n",
       "        2.28651373e-02,  3.21262588e-02,  5.87427559e-03, -1.14844461e-03,\n",
       "       -3.86109209e-03, -8.47595879e-03, -2.05969213e-03, -1.43125473e-02,\n",
       "        2.19897434e-03,  9.58858407e-03,  2.32193142e-02,  1.16904894e-02,\n",
       "       -4.76919166e-03,  1.16868354e-02, -1.48774100e-02, -1.92810408e-02,\n",
       "        3.56396934e-02,  2.70041229e-03,  2.32383406e-02, -1.65150381e-02,\n",
       "       -2.49022650e-02,  8.62046772e-03,  2.23166014e-02,  9.70776940e-03,\n",
       "        4.80342174e-03,  4.79884346e-03,  5.00921446e-03,  1.51641712e-03,\n",
       "       -3.59802278e-03,  1.66897055e-02,  2.98778799e-03, -2.15594593e-02,\n",
       "        2.49323003e-03,  7.44110910e-03, -8.44241107e-03,  2.39158010e-02,\n",
       "       -1.19136832e-02,  9.69245379e-03,  2.00840590e-03, -9.04722694e-04,\n",
       "       -1.47563170e-02, -2.43008070e-03,  2.17135006e-03, -1.79557529e-02,\n",
       "        3.44918491e-02,  1.74977760e-03,  9.54519603e-03,  6.42219524e-03,\n",
       "       -1.66936537e-02,  4.68769247e-04, -1.81411447e-03,  1.85251602e-02,\n",
       "        1.14944851e-02,  2.06589255e-03, -4.64508474e-03, -8.45959999e-03,\n",
       "        3.03143041e-05, -5.17820661e-03, -6.36837059e-03,  1.47388959e-02,\n",
       "        3.46380986e-04, -1.25266377e-02, -4.46161913e-03,  5.16191574e-03,\n",
       "        1.26243904e-02,  1.32331062e-02,  5.91734276e-03, -1.73719005e-04,\n",
       "        2.83501281e-02,  9.55014008e-03,  1.71316389e-02, -1.08775863e-02,\n",
       "        8.47203425e-03,  8.01628434e-03,  1.40107418e-03, -8.23737913e-03,\n",
       "        6.25523243e-03,  4.67138486e-02, -1.11634157e-02, -2.57885426e-03,\n",
       "        2.50158536e-03,  1.75513122e-02, -5.79710693e-03, -2.23722384e-03,\n",
       "        8.48730762e-03,  9.70327883e-03,  1.30442464e-02,  9.14822861e-03,\n",
       "        1.17900429e-02, -3.33146968e-03,  1.04255173e-02, -4.12032794e-03,\n",
       "        2.18081379e-02,  8.82719568e-03,  6.10721355e-03,  1.60898549e-02,\n",
       "        1.53821709e-04,  6.05174885e-03,  1.59686140e-02,  1.70488875e-02,\n",
       "       -3.91666146e-03, -1.47598973e-02,  3.19940719e-03, -4.61025411e-03,\n",
       "       -3.91282159e-03, -6.37911941e-03, -8.88375216e-03,  1.45818707e-02,\n",
       "       -1.15998873e-02,  4.82990069e-03,  3.86462631e-03,  4.89530818e-03,\n",
       "        5.56997973e-03,  6.54711244e-03, -9.82066461e-03, -2.36027103e-02,\n",
       "        8.77341141e-05, -7.08961812e-04,  9.27250067e-03,  1.90039963e-03,\n",
       "        4.63899767e-04,  5.47603754e-03,  6.79468705e-03, -5.67742747e-03,\n",
       "        1.35497645e-02, -2.35568954e-03, -8.19845879e-03, -2.35523134e-02,\n",
       "       -8.77860410e-03, -1.99437214e-02, -1.45750002e-02,  1.22395623e-02,\n",
       "        1.76811533e-02, -2.42452878e-03, -1.60122161e-02,  2.24680016e-04,\n",
       "        9.06027268e-03, -2.11853852e-02, -1.13277530e-02,  3.89444979e-02,\n",
       "        1.20751582e-02, -4.75252471e-03, -3.37838047e-03, -6.63954754e-03,\n",
       "       -1.34570194e-04,  1.78333027e-02])"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "xSlater, Slater_status = solve_slater_point(Q, alpha, s, Dinv_half, solSavePath='../slaterPoint/bio-DM-LC-Slater')\n",
    "xSlater"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'optimal'"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "Slater_status"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "-0.01128719515160698"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "constraint(xSlater, Q, alpha, s, Dinv_half, b)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "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"
     ]
    }
   ],
   "source": [
    "xOpt, Opt_status = solve_opt(Q, alpha, s, Dinv_half, b, D_half, solSavePath='../cvxpySol/bio-DM-LC-Opt')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0.00000000e+00, 0.00000000e+00, 0.00000000e+00, 0.00000000e+00,\n",
       "       0.00000000e+00, 6.31397712e-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, 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, 0.00000000e+00, 0.00000000e+00,\n",
       "       0.00000000e+00, 9.67199324e-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, 0.00000000e+00, 0.00000000e+00,\n",
       "       0.00000000e+00, 0.00000000e+00, 0.00000000e+00, 0.00000000e+00,\n",
       "       3.25729039e-04, 1.53695439e-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, 5.78982055e-04, 0.00000000e+00,\n",
       "       5.62984739e-03, 0.00000000e+00, 0.00000000e+00, 0.00000000e+00,\n",
       "       0.00000000e+00, 1.03960549e-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, 0.00000000e+00, 8.07608274e-04,\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, 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, 2.36288494e-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",
       "       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, 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, 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, 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, 8.14202180e-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, 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, 3.43790132e-03, 0.00000000e+00, 2.47818977e-02,\n",
       "       0.00000000e+00, 1.58992044e-02, 6.43262747e-04, 0.00000000e+00,\n",
       "       3.18892204e-03, 0.00000000e+00, 0.00000000e+00, 0.00000000e+00,\n",
       "       0.00000000e+00, 9.42496200e-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, 1.59568444e-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, 6.71545636e-03, 1.27173586e-03,\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",
       "       5.14443674e-03, 0.00000000e+00, 0.00000000e+00, 0.00000000e+00,\n",
       "       0.00000000e+00, 0.00000000e+00, 1.31498178e-02, 0.00000000e+00,\n",
       "       0.00000000e+00, 0.00000000e+00, 1.18663929e-03, 0.00000000e+00,\n",
       "       0.00000000e+00, 0.00000000e+00, 0.00000000e+00, 0.00000000e+00,\n",
       "       1.70267690e-03, 0.00000000e+00, 0.00000000e+00, 0.00000000e+00,\n",
       "       0.00000000e+00, 1.68161080e-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, 0.00000000e+00, 0.00000000e+00,\n",
       "       0.00000000e+00, 0.00000000e+00, 1.54618135e-02, 0.00000000e+00,\n",
       "       1.52288643e-03, 0.00000000e+00, 0.00000000e+00, 0.00000000e+00,\n",
       "       9.21392269e-03, 0.00000000e+00, 0.00000000e+00, 0.00000000e+00,\n",
       "       0.00000000e+00, 0.00000000e+00, 0.00000000e+00, 3.27737390e-02,\n",
       "       0.00000000e+00, 0.00000000e+00, 1.92056362e-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",
       "       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, 1.97155025e-04, 0.00000000e+00, 0.00000000e+00,\n",
       "       0.00000000e+00, 0.00000000e+00, 0.00000000e+00, 0.00000000e+00,\n",
       "       1.14394555e-02, 0.00000000e+00, 0.00000000e+00, 0.00000000e+00,\n",
       "       0.00000000e+00, 0.00000000e+00, 3.13171706e-03, 1.20243093e-02,\n",
       "       0.00000000e+00, 0.00000000e+00, 0.00000000e+00, 0.00000000e+00,\n",
       "       8.82443143e-03, 3.05961626e-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, 0.00000000e+00, 0.00000000e+00,\n",
       "       0.00000000e+00, 0.00000000e+00, 0.00000000e+00, 0.00000000e+00,\n",
       "       0.00000000e+00, 2.81667116e-02, 4.31946821e-02, 0.00000000e+00,\n",
       "       0.00000000e+00, 0.00000000e+00, 0.00000000e+00, 0.00000000e+00,\n",
       "       0.00000000e+00, 8.37788500e-05, 2.47209080e-03, 1.17579290e-02,\n",
       "       3.88221065e-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, 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, 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, 0.00000000e+00, 0.00000000e+00,\n",
       "       0.00000000e+00, 0.00000000e+00, 2.52499080e-02, 7.30637625e-03,\n",
       "       0.00000000e+00, 1.80175246e-02, 4.89070083e-03, 0.00000000e+00,\n",
       "       0.00000000e+00, 0.00000000e+00, 0.00000000e+00, 0.00000000e+00,\n",
       "       0.00000000e+00, 1.59498286e-02, 0.00000000e+00, 3.50804400e-03,\n",
       "       0.00000000e+00, 0.00000000e+00, 0.00000000e+00, 0.00000000e+00,\n",
       "       0.00000000e+00, 8.66539433e-03, 0.00000000e+00, 0.00000000e+00,\n",
       "       1.81626773e-02, 0.00000000e+00, 0.00000000e+00, 0.00000000e+00,\n",
       "       0.00000000e+00, 4.17972499e-03, 1.34768579e-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",
       "       0.00000000e+00, 0.00000000e+00, 2.29075898e-02, 0.00000000e+00,\n",
       "       0.00000000e+00, 0.00000000e+00, 0.00000000e+00, 9.55867015e-03,\n",
       "       0.00000000e+00, 0.00000000e+00, 0.00000000e+00, 1.27132896e-02,\n",
       "       0.00000000e+00, 0.00000000e+00, 6.55835291e-03, 0.00000000e+00,\n",
       "       0.00000000e+00, 0.00000000e+00, 0.00000000e+00, 0.00000000e+00,\n",
       "       0.00000000e+00, 9.29875212e-03, 0.00000000e+00, 0.00000000e+00,\n",
       "       0.00000000e+00, 0.00000000e+00, 0.00000000e+00, 0.00000000e+00,\n",
       "       3.81564142e-03, 0.00000000e+00, 7.77381001e-03, 0.00000000e+00,\n",
       "       0.00000000e+00, 0.00000000e+00, 0.00000000e+00, 0.00000000e+00,\n",
       "       6.18238105e-04, 5.53145463e-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, 6.40410741e-03, 3.96826443e-03,\n",
       "       8.11576743e-03, 0.00000000e+00, 1.14583798e-02, 2.76839215e-04,\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, 0.00000000e+00, 0.00000000e+00,\n",
       "       0.00000000e+00, 3.10715294e-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, 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, 8.85265778e-04, 6.08944450e-03, 0.00000000e+00,\n",
       "       0.00000000e+00, 0.00000000e+00, 0.00000000e+00, 0.00000000e+00,\n",
       "       1.18132212e-02, 2.10743446e-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, 1.68919847e-02, 5.36314697e-03,\n",
       "       0.00000000e+00, 5.35949292e-03, 0.00000000e+00, 0.00000000e+00,\n",
       "       2.69091679e-02, 0.00000000e+00, 1.23350889e-02, 0.00000000e+00,\n",
       "       0.00000000e+00, 0.00000000e+00, 1.10489067e-02, 9.45842728e-04,\n",
       "       0.00000000e+00, 0.00000000e+00, 0.00000000e+00, 0.00000000e+00,\n",
       "       0.00000000e+00, 3.39832832e-03, 0.00000000e+00, 0.00000000e+00,\n",
       "       0.00000000e+00, 0.00000000e+00, 0.00000000e+00, 1.44949528e-02,\n",
       "       0.00000000e+00, 1.62214917e-03, 0.00000000e+00, 0.00000000e+00,\n",
       "       0.00000000e+00, 0.00000000e+00, 0.00000000e+00, 0.00000000e+00,\n",
       "       2.68304004e-02, 0.00000000e+00, 0.00000000e+00, 0.00000000e+00,\n",
       "       0.00000000e+00, 0.00000000e+00, 0.00000000e+00, 7.62190477e-03,\n",
       "       3.03585123e-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, 0.00000000e+00,\n",
       "       4.15030060e-03, 7.96957536e-04, 0.00000000e+00, 0.00000000e+00,\n",
       "       2.08295728e-02, 2.02946993e-03, 9.01326793e-03, 0.00000000e+00,\n",
       "       4.92983104e-04, 0.00000000e+00, 0.00000000e+00, 0.00000000e+00,\n",
       "       0.00000000e+00, 3.67544590e-02, 0.00000000e+00, 0.00000000e+00,\n",
       "       0.00000000e+00, 8.20175976e-03, 0.00000000e+00, 0.00000000e+00,\n",
       "       0.00000000e+00, 0.00000000e+00, 5.96248175e-03, 0.00000000e+00,\n",
       "       0.00000000e+00, 0.00000000e+00, 0.00000000e+00, 0.00000000e+00,\n",
       "       1.28864546e-02, 0.00000000e+00, 0.00000000e+00, 0.00000000e+00,\n",
       "       0.00000000e+00, 0.00000000e+00, 7.21847244e-03, 1.13916638e-02,\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, 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, 2.42833489e-03, 0.00000000e+00,\n",
       "       0.00000000e+00, 0.00000000e+00, 0.00000000e+00, 0.00000000e+00,\n",
       "       5.78564828e-03, 0.00000000e+00, 0.00000000e+00, 0.00000000e+00,\n",
       "       0.00000000e+00, 0.00000000e+00, 0.00000000e+00, 0.00000000e+00,\n",
       "       1.01503103e-02, 0.00000000e+00, 0.00000000e+00, 0.00000000e+00,\n",
       "       0.00000000e+00, 0.00000000e+00, 0.00000000e+00, 2.61962300e-02,\n",
       "       0.00000000e+00, 0.00000000e+00, 0.00000000e+00, 0.00000000e+00,\n",
       "       0.00000000e+00, 1.16121790e-02])"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "xOpt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'optimal'"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "Opt_status"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([  5,  33,  52,  53,  66,  68,  73,  83, 102, 157, 181, 183, 185,\n",
       "        186, 188, 193, 205, 214, 215, 224, 230, 234, 240, 245, 258, 260,\n",
       "        264, 271, 274, 293, 300, 306, 307, 312, 313, 333, 334, 341, 342,\n",
       "        343, 344, 382, 383, 385, 386, 393, 395, 401, 404, 409, 410, 422,\n",
       "        427, 431, 434, 441, 448, 450, 456, 457, 466, 467, 468, 470, 471,\n",
       "        485, 505, 506, 512, 513, 522, 523, 525, 528, 530, 534, 535, 541,\n",
       "        547, 549, 556, 563, 564, 576, 577, 580, 581, 582, 584, 589, 593,\n",
       "        598, 604, 610, 611, 630, 636, 644, 651, 657]),)"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "xOpt[abs(xOpt) < 1e-08] = 0\n",
    "np.nonzero(xOpt)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "100"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.count_nonzero(xOpt)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<658x658 sparse matrix of type '<class 'numpy.float64'>'\n",
       "\twith 2916 stored elements in Compressed Sparse Row format>"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "Q"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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
}
