{
 "cells": [
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## choose proper b for running"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "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": 13,
   "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": [
    "### bn-cat-mixed-species_brain_1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "data = '../data/bn-cat-mixed-species_brain_1.npz'\n",
    "alpha = 0.4\n",
    "b = -0.1\n",
    "Q, alpha, s, Dinv_half, D_half = dataPreprocess(data, alpha, random_seed = 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<65x65 sparse matrix of type '<class 'numpy.float64'>'\n",
       "\twith 1525 stored elements in Compressed Sparse Row format>"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "Q"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Slater point already exists!\n",
      "\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "array([ 2.29508849e-01,  7.26281800e-02,  1.02495481e-01,  2.17724630e-01,\n",
       "        1.68700789e-01, -4.66579905e-02,  9.75091484e-02,  1.23265175e-02,\n",
       "       -2.60264497e-04,  6.41379300e-02,  3.95119614e-02,  1.12006036e-01,\n",
       "        5.54971952e-02,  2.81950690e-02,  3.62380055e-02,  2.03311786e-02,\n",
       "        1.61621854e-01, -8.65915664e-03,  2.78135772e-02, -9.69390833e-02,\n",
       "       -3.07606966e-01,  5.92385546e-02,  7.99708383e-02, -8.56679012e-02,\n",
       "        4.25791984e-01, -1.12715691e-01,  2.13734464e-02, -3.09076496e-02,\n",
       "        1.57272199e-01,  1.31270696e-01,  2.51819986e-02,  4.45040941e-02,\n",
       "       -6.70249049e-02, -1.54007463e-01, -2.34487138e-02,  1.07406811e-02,\n",
       "        9.18552934e-02,  6.95917584e-02, -4.58369061e-02, -2.60387365e-02,\n",
       "       -6.29883946e-02, -1.05889105e-01, -1.13270323e-01,  1.39496845e-01,\n",
       "       -3.61970248e-02, -3.63758594e-02, -1.09437157e-01,  4.34327915e-02,\n",
       "       -1.29989089e-01, -2.54525785e-02, -6.03190219e-02,  1.85814187e-02,\n",
       "       -3.16927375e-02, -8.37988694e-02, -1.39144156e-02,  3.18099899e-02,\n",
       "       -5.08900163e-03,  1.26801334e-02, -4.53385276e-02, -2.54716320e-02,\n",
       "       -8.03838308e-02, -5.80085609e-02, -9.51779977e-02, -3.43989022e-01,\n",
       "       -6.36126677e-03])"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "xSlater, Slater_status = solve_slater_point(Q, alpha, s, Dinv_half, solSavePath = '../slaterPoint/bn-cat-mixed-species_brain_1-Slater.npy')\n",
    "xSlater"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'optimal'"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "Slater_status"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "-0.1864656677846335"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "constraint(xSlater, Q, alpha, s, Dinv_half, b)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Optimal solution of cvxpy already exists!\n",
      "\n"
     ]
    }
   ],
   "source": [
    "xOpt, Opt_status = solve_opt(Q, alpha, s, Dinv_half, b, D_half, solSavePath = '../cvxpySol/bn-cat-mixed-species_brain_1-Opt.npy')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([ 1.94800489e-11,  1.38839981e-12,  1.45691044e-12,  6.68829508e-12,\n",
       "        3.19008801e-12, -1.64995446e-12,  2.88535882e-12, -7.63785345e-13,\n",
       "       -6.96634704e-13,  1.17160847e-12,  4.31905481e-13,  1.33246139e-12,\n",
       "        9.28441126e-13,  2.99003815e-12,  3.35109069e-13,  1.99115989e-13,\n",
       "        7.35479204e-12, -4.18403228e-13,  1.65083538e-12, -2.36303777e-12,\n",
       "       -6.27342791e-02,  2.86774575e-12,  3.01995107e-12, -4.55312120e-12,\n",
       "        2.73924890e-01, -1.74732491e-12,  2.14939780e-13, -9.47026479e-13,\n",
       "        6.93723381e-12,  4.05369301e-12,  5.30096827e-13,  1.14626679e-12,\n",
       "       -1.48880264e-12, -3.13862898e-12, -5.03136739e-13,  2.25538167e-13,\n",
       "        1.65770577e-12,  1.05762666e-12, -2.19841258e-12, -4.93042932e-13,\n",
       "       -1.03042220e-12, -1.94273593e-12, -2.40004109e-12,  2.94598615e-12,\n",
       "       -6.86249084e-13, -6.11191963e-13, -2.16980874e-12,  7.79875471e-13,\n",
       "       -2.34103888e-12, -2.74483316e-13, -5.89259034e-13,  2.71085702e-13,\n",
       "       -2.92701309e-13, -1.32671645e-12, -2.48690991e-14,  8.80533359e-13,\n",
       "        1.23331490e-13,  7.62990891e-13, -4.64965765e-13, -2.56776703e-13,\n",
       "       -2.59506523e-12, -1.71763426e-12, -1.74886384e-12, -1.71731843e-01,\n",
       "        1.93776752e-13])"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "xOpt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'optimal'"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "Opt_status"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([20, 24, 63]),)"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "xOpt[abs(xOpt) < 1e-08] = 0\n",
    "np.nonzero(xOpt)"
   ]
  },
  {
   "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
}
