{
 "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": [
    "## DD242"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "data = '../data/DD242.npz'\n",
    "alpha = 0.4\n",
    "b = -0.03\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": [
       "<1284x1284 sparse matrix of type '<class 'numpy.float64'>'\n",
       "\twith 7890 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([-0.02407906, -0.00956292, -0.01046914, ...,  0.0050822 ,\n",
       "       -0.0136275 , -0.00598713])"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "xSlater, Slater_status = solve_slater_point(Q, alpha, s, Dinv_half, solSavePath='../slaterPoint/DD242-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.021666477109722096"
      ]
     },
     "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": [],
   "source": [
    "xOpt, Opt_status = solve_opt(Q, alpha, s, Dinv_half, b, D_half, solSavePath='../cvxpySol/DD242-Opt')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([-0.01179311, -0.00241457, -0.00199544, ...,  0.00146736,\n",
       "       -0.00955421, -0.00134993])"
      ]
     },
     "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([   0,    1,    2,    3,    4,   16,   20,   22,   23,   24,   25,\n",
       "          28,   29,   33,   36,   37,   40,   41,   42,   43,   46,   48,\n",
       "          50,   53,   62,   63,   66,   68,   73,   76,   77,   80,   81,\n",
       "          83,   84,   85,   89,   91,   93,   95,   97,  100,  101,  102,\n",
       "         103,  104,  105,  108,  109,  110,  111,  113,  119,  121,  123,\n",
       "         127,  128,  139,  140,  144,  147,  148,  151,  156,  157,  158,\n",
       "         161,  164,  167,  168,  170,  174,  176,  181,  183,  185,  186,\n",
       "         189,  190,  193,  197,  198,  199,  202,  205,  214,  218,  224,\n",
       "         230,  234,  235,  236,  237,  239,  245,  246,  247,  249,  256,\n",
       "         257,  258,  259,  260,  264,  271,  272,  278,  279,  281,  283,\n",
       "         289,  290,  292,  293,  295,  301,  306,  307,  311,  312,  324,\n",
       "         327,  331,  333,  334,  336,  339,  343,  350,  351,  352,  355,\n",
       "         356,  357,  358,  362,  371,  377,  379,  380,  382,  383,  385,\n",
       "         386,  387,  388,  393,  397,  398,  399,  401,  404,  406,  410,\n",
       "         414,  418,  419,  420,  422,  427,  430,  431,  432,  434,  436,\n",
       "         444,  450,  455,  457,  460,  461,  465,  466,  468,  470,  474,\n",
       "         475,  476,  477,  478,  479,  480,  482,  484,  485,  490,  492,\n",
       "         493,  494,  502,  506,  507,  509,  511,  512,  513,  517,  519,\n",
       "         521,  522,  523,  526,  527,  528,  530,  543,  546,  547,  548,\n",
       "         552,  555,  556,  558,  560,  563,  571,  579,  580,  582,  583,\n",
       "         589,  593,  598,  600,  604,  607,  610,  611,  613,  618,  619,\n",
       "         625,  627,  639,  641,  643,  649,  651,  657,  661,  667,  668,\n",
       "         671,  672,  677,  678,  681,  683,  684,  685,  686,  687,  689,\n",
       "         692,  693,  694,  699,  700,  701,  702,  703,  705,  706,  708,\n",
       "         714,  716,  724,  725,  727,  731,  733,  734,  735,  737,  740,\n",
       "         741,  742,  748,  750,  751,  753,  759,  768,  772,  775,  778,\n",
       "         780,  783,  788,  790,  792,  793,  794,  797,  800,  803,  804,\n",
       "         808,  811,  812,  815,  817,  818,  822,  827,  828,  831,  843,\n",
       "         844,  846,  848,  850,  851,  853,  854,  856,  868,  870,  874,\n",
       "         875,  877,  879,  880,  881,  892,  894,  895,  897,  898,  900,\n",
       "         901,  905,  907,  911,  912,  913,  914,  915,  920,  921,  922,\n",
       "         925,  928,  929,  930,  936,  937,  941,  943,  947,  950,  952,\n",
       "         956,  958,  959,  961,  963,  967,  968,  969,  971,  973,  974,\n",
       "         977,  983,  988,  990,  992,  998, 1006, 1007, 1010, 1011, 1013,\n",
       "        1017, 1020, 1021, 1023, 1024, 1027, 1030, 1033, 1034, 1035, 1039,\n",
       "        1040, 1044, 1047, 1051, 1053, 1054, 1056, 1057, 1059, 1061, 1065,\n",
       "        1070, 1071, 1073, 1076, 1077, 1078, 1083, 1085, 1086, 1087, 1092,\n",
       "        1094, 1096, 1100, 1102, 1107, 1108, 1111, 1113, 1114, 1115, 1118,\n",
       "        1120, 1121, 1122, 1126, 1129, 1130, 1138, 1140, 1141, 1142, 1143,\n",
       "        1144, 1148, 1151, 1155, 1158, 1159, 1161, 1162, 1164, 1166, 1171,\n",
       "        1172, 1174, 1179, 1180, 1184, 1187, 1188, 1189, 1191, 1194, 1195,\n",
       "        1198, 1199, 1200, 1201, 1202, 1204, 1205, 1207, 1208, 1209, 1216,\n",
       "        1218, 1222, 1228, 1233, 1234, 1235, 1236, 1238, 1239, 1240, 1242,\n",
       "        1249, 1250, 1252, 1253, 1255, 1256, 1257, 1258, 1261, 1263, 1266,\n",
       "        1267, 1268, 1269, 1270, 1271, 1272, 1273, 1274, 1277, 1278, 1279,\n",
       "        1281, 1282, 1283]),)"
      ]
     },
     "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": [
       "498"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.count_nonzero(xOpt)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1284"
      ]
     },
     "execution_count": 26,
     "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.9.13"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
