{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "import random\n",
    "import warnings\n",
    "import numpy as np\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "from numpy.linalg import inv\n",
    "from sklearn.preprocessing import StandardScaler\n",
    "\n",
    "cmap = 'Blues'\n",
    "warnings.filterwarnings('ignore')\n",
    "sys.path.insert(0, '../GRAPH_Framework-main')\n",
    "from tasks.experiment import ModelTest"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Experiment"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Precision"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x250 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from utils.common import simulation_random_graph\n",
    "random.seed(1)\n",
    "np.random.seed(1)\n",
    "\n",
    "g = 4\n",
    "n = 100\n",
    "N_lt = [10*n]*g\n",
    "D_lt, Sigma = simulation_random_graph(n, N_lt, g=g, prep=5)\n",
    "\n",
    "Sinv = []\n",
    "for i in range(len(Sigma)):\n",
    "    Sinv.append(inv(Sigma[i]))\n",
    "\n",
    "g = 2\n",
    "Sinv = [Sinv[0].copy(), Sinv[2].copy()]\n",
    "D_lt = [D_lt[0].copy(), D_lt[2].copy()]\n",
    "Sigma = [Sigma[0].copy(), Sigma[2].copy()]\n",
    "D = np.concatenate(D_lt, axis=0)\n",
    "\n",
    "fig, axs = plt.subplots(1, g, figsize=(2.5*g, 2.5))\n",
    "for i in range(g):\n",
    "    sns.heatmap(np.abs(Sinv[i]-np.diag(np.diag(Sinv[i]))), ax=axs[i], cmap=cmap, cbar=False)\n",
    "    axs[i].set_title('Ground Truth Precision (group '+str(i+1)+')', fontsize=7)\n",
    "    axs[i].axis('off')\n",
    "    \n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "parameters = {'max_iter':1000, 'outer_max_iter':25, 'lam':0.05, 'lamm':0.05, 'rhom':1, 'tol':1e-5}\n",
    "precision_test = ModelTest(model_type='Precision',showfig=False)\n",
    "precision_test.group_graph(D,D_lt,parameters)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[1mGraph Learning\u001b[0m\n",
      "\u001b[4moverall global results:\u001b[0m 97.17169\n",
      "\u001b[4mdisparity error:\u001b[0m 7.814884 \n",
      "\n",
      "\u001b[1mObjective Fair Graph Learning\u001b[0m\n",
      "\u001b[4moverall global results:\u001b[0m 97.44279\n",
      "\u001b[4mdisparity error:\u001b[0m 0.623717\n",
      "\u001b[3mobjective improvement: -0.27110 (-0.27899%)\u001b[0m\n",
      "\u001b[3mdisparity improvement: 7.191167 (92.01886%)\u001b[0m\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x250 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "precision_test.runtime(1,D,D_lt,parameters)\n",
    "precision_test.summary()\n",
    "precision_test.plot()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Covariance"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAekAAADwCAYAAAAkYJxwAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAAA7wUlEQVR4nO2deXxV1bm/H4YwhyRAEmbCDGEKBFARGwRsrThPtUXF1qu3k1j9tdXWa0Gv9qod/Ki3vR30erUOxRFxprUgiIKAzAjIEOYZkhBIGJL9+2PttdfO3lATC3hO8n3+gey9zjl75/Bw1nvetd63nud5HkIIIYRIOOp/2RcghBBCiOOjD2khhBAiQdGHtBBCCJGg6ENaCCGESFD0IS2EEEIkKPqQFkIIIRIUfUgLIYQQCYo+pIUQQogERR/SQgghRIKS8B/SW7Zs4YorrqBbt27k5+czduxYPv7449N6DW3atKnyc2FhIXl5eeTl5dGqVSu6detGXl4eV155ZbWeb+bMmVXu4YYbbuCNN9743MetWLGC8847j549ezJkyBBuvPFGDh06VLObqQEXXHABZWVlp+z5T8THH3/MxIkTT/vrHo/LLruMjIyMKu/tsWPHGD16NMeOHfsSryy5kMcOeXx62bx5M6NGjSI3N5eBAwfy4osvBufGjRvH/v37v8SrqwZeAlNZWenl5+d7TzzxRHBs0aJF3vPPPx8be+zYsVN2Ha1btz7huQkTJnivv/56ja5n0qRJ3mOPPfa5zxHm4MGDXk5Ojvf2228Hx1555RVvx44d//RxX5RT+fv8PC699FJv9erV1R5/Kq91xowZ3rRp07wrrriiyvH777/fe+65507Z69Ym5LFDHp+YU3Wt27Zt8xYtWuR5nudt377da9++vVdaWup5nuc9++yz3i9/+ctT8roni4T+kJ4+fbo3atSoE56fMGGC993vftcbNmyYd99993nvvvuuN2jQIK9fv37ebbfd5lVWVnqeV1XOxx57zJs0aZLneZ5XUFDg/fSnP/Xy8/O9fv36ecuXL/c8z/N27drlnXvuuV6/fv28O+64o9pyFxQUeLfeequXn5/vPfnkk15BQYG3bNkyz/M8b9myZV5BQYG3adMmLzs72+vQoYM3aNAgb9GiRd6ECRO8iRMnemeccYbXo0cPb+bMmbHX+fOf/+xdf/31x72G3bt3exdeeKE3YMAAr6CgwNuwYYNXVFTk9ejRIxhTWFjoDRo0yPM8z/vFL37hDR061OvXr5/3ox/9KBjTpUsX74477vDy8vK86dOne126dPEOHDjgeZ7njRs3zhsyZIjXr18/75lnnvE8z/M2bNjgDRw40Lv++uu9Pn36eFdffXXwO587d653xhlneAMHDvQKCgo8z/O80tJSb8KECd7QoUO9IUOGeNOnT4/dS1FRkTdgwIDg5x07dnijRo3y+vXr5915553Be/Hkk096l112mVdQUOBddtll3rp167yCggJvwIAB3kUXXeTt3bs3eE+i74Hnmf9gJ0yY4A0fPtzr2bOnN2XKlBO9xd6MGTNiH9LLli3zLrroohM+RjjksUMef3keWwYOHOht2rTJ8zzPKy4uDn6fiUpCf9396aefkpeX90/H7N27l3nz5nH77bdz0003MXXqVJYuXcrq1at59dVXP/c1UlJSWLBgAbfffju//e1vAbjnnnu48MILWb58OV26dKnRNdvnu+GGG457vlOnTnz3u9/lzjvvZPHixcH97du3j7lz5/LHP/6Re++9N/a4lStXMmTIkOM+5+TJkznnnHNYunQp3/ve95g4cSJpaWn07t2befPmAfDSSy9x1VVXAXDrrbcyf/58li1bxqZNm5gzZ06V61u0aBHnnXdeldd4+umnWbhwIfPmzeP+++/n8OHDgHmP7rjjDlauXMnOnTv54IMPOHLkCOPHj+fxxx9nyZIlvPLKKwDcf//9XHjhhcyfP593332XW265BS/S32XhwoUMGDAg+Pmee+7hkksuYfny5XTv3r3K2CVLljBt2jReeeUVJk6cyPe//32WLl3K2WefzeTJk4/7uwqzfPlyZs2axezZs/nJT35CSUnJ5z7GkpubyyeffFLt8XUZeeyQx1+uxwsXLqSiooJOnToB0LJlS8rLy2vk/ukmoT+ko1x55ZXk5uZy0003VTlWr149Vq9eTe/evcnJyaF+/fqMHz+e2bNnf+5zXnbZZQDk5+dTWFgIwAcffMA111wDwPjx42t0jVagmnLppZfGrqO6fPDBB1x77bUAXH311UGe7KqrrgryLy+//HJwbe+99x7Dhw9n0KBBzJkzh5UrV37u9T/88MMMGjSIESNGsGnTJjZt2gRA7969yc3NpV69egwePJjCwkJWrVpFTk4O/fv3B6BV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",
      "text/plain": [
       "<Figure size 500x250 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from utils.common import simulation_random_graph\n",
    "random.seed(1)\n",
    "np.random.seed(1)\n",
    "\n",
    "g = 4\n",
    "n = 100\n",
    "N_lt = [10*n]*g\n",
    "D_lt, Sigma = simulation_random_graph(n, N_lt, g=g, prep=5)\n",
    "\n",
    "g = 2\n",
    "Sigma = [Sigma[0].copy(), Sigma[2].copy()]\n",
    "D_lt = [D_lt[0].copy(), D_lt[2].copy()]\n",
    "D = np.concatenate(D_lt, axis=0)\n",
    "\n",
    "fig, axs = plt.subplots(1, g, figsize=(2.5*g, 2.5))\n",
    "for i in range(g):\n",
    "    sns.heatmap(np.abs(Sigma[i]-np.diag(np.diag(Sigma[i]))), ax=axs[i], cmap=cmap, cbar=False)\n",
    "    axs[i].set_title('Ground Truth Covariance (group '+str(i+1)+')', fontsize=7)\n",
    "    axs[i].axis('off')\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "parameters = {'max_iter':1000, 'outer_max_iter':25,'tau':0.01, 'lam':0.05, 'lamm':0.05, 'rhom':1, 'tol':1e-5}\n",
    "covariance_test = ModelTest(model_type='Covariance',showfig=True)\n",
    "covariance_test.group_graph(D,D_lt,parameters)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[1mGraph Learning\u001b[0m\n",
      "\u001b[4moverall global results:\u001b[0m 14.31927\n",
      "\u001b[4mdisparity error:\u001b[0m 5.262695 \n",
      "\n",
      "\u001b[1mObjective Fair Graph Learning\u001b[0m\n",
      "\u001b[4moverall global results:\u001b[0m 14.48444\n",
      "\u001b[4mdisparity error:\u001b[0m 0.388927\n",
      "\u001b[3mobjective improvement: -0.16517 (-1.15349%)\u001b[0m\n",
      "\u001b[3mdisparity improvement: 4.873768 (92.60974%)\u001b[0m\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAekAAADwCAYAAAAkYJxwAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAABHMElEQVR4nO2de3yU5Zn+L86QkJCQEwmQBBIIBBLCSRRRELS2th6qVEVbZFXa/nTb1XV1Xbut3a662tbWVbe11RVt63HdFcVaKSrigaooEM6BEMIhQCCQEwESDvP743nu93lmMpnM5Pi+k+v7+fgxzPu+c0jmnnmu577v6+7l8/l8IIQQQojr6N3dT4AQQgghweGXNCGEEOJS+CVNCCGEuBR+SRNCCCEuhV/ShBBCiEvhlzQhhBDiUvglTQghhLgUfkkTQgghLoVf0oQQQohL4Zd0F7Jv3z5cc801GD16NKZOnYqLL74Yn3/+OQBg0aJFeOutt0Jen5ycHNHjzZkzB5s2bWp2e2NjI26//Xbk5OQgNzcXCxYsQHV1dav39/Of/zyixw9k6dKl2L59e7vug5DOoG/fvigqKnL+O3HiRNDz3nzzTfz6178O6z5fe+01TJw4EePGjcPUqVPxwQcftHpNe2OkvLwcr776aovH9+7di/nz57f5/m3sz6zHHnsMTU1NzrGLLroIAFBSUoJFixZ1yOP1VPgl3UX4fD5cddVV+PrXv46ysjJ8+eWX+OUvf4mysrIufy733nsvTp8+jR07dqC0tBQTJ07EzTff3Op1/JIm0UpCQgLWr1/v/Ddo0KCg511xxRW48847m91+5swZv3+vW7cO//Iv/4K3334b27Ztw5IlS7Bw4UIcOHAg5PPo7C/pRx99FN/97nfbfP8tEfglvXLlSgBAXl4eKisrsW/fvg5/zB6Dj3QJf/3rX31z5sxp8fhNN93kW7Zsmc/n8/mWL1/umzRpkm/ChAm+O++803f27Fmfz+fzJSUl+W677TZffn6+77LLLvPV1tb6fD6f77e//a1v2rRpvsLCQt+CBQt8TU1NPp/P55s9e7Zv48aNfo9z7Ngx39ChQ311dXXObWfOnPGNGjXKt2PHDt/KlSt911xzjXPsmmuu8a1cudJ33333+fr06eObNGmS73vf+55v165dvoKCAt+3vvUt37hx43wLFy70nTp1yufz+XxZWVm++vp6n8/n8y1btsx30003+T799FNfYmKib9SoUb5Jkyb5Kisr2/srJaTDSEpK8vt3aWmpb9asWb7Jkyf7pk+f7lu3bp3P5/P5lixZ4rvrrrt8Pp+K2e9///u+6dOn+x544AG/62+88Ubfs88+63fbT37yE9+PfvQjn88XfozMnj3bd8cdd/gKCwt9RUVFvk2bNvl8Pp/v/vvv9z3xxBPNnv/MmTN9Q4YM8U2aNMn39NNPN3udOTk5TpwuWbLEd8011/jmzp3ry8zM9D333HO++++/31dQUOC75JJLfCdPnmzxucrrX7Zsme/JJ5/09evXz1dQUOC7/PLLm/0+n3jiCd+jjz7a6t+ABIdKuovYunUrioqKWj3vxIkTWLx4MZYuXYoNGzagpKQEr7/+OgDgyJEjmDt3LjZv3ozCwkL86le/AgBce+21WLNmDYqLizFs2LCQK+mdO3ciMzMTcXFxzm29e/fGpEmTsGXLlhave/DBBx218dRTTwEANm3ahHvuuQdbt27FqVOn8Kc//anF62fMmIErrrgCjz/+ONavX4/U1NRWfxeEdBU1NTXOVvett96K9PR0vPvuu1i7di2eeeYZ3H333UGvO3LkCD777DP86Ec/8rt9y5YtmDJlit9tU6ZMCRljLcXI6dOnUVxcjIcffhi33357yNfx4IMP4uKLL8b69etx6623+h0rKytDWloa+vbt6/c8ly1bho8//hi33347JkyYgA0bNiApKQlvv/12yMcSbr/9dmRkZGD16tV48803mx2fMmUKVq9eHdZ9kebwS7qbmD9/PvLz87F48WK/20tKSpCXl4fs7Gz07t0bN954Iz766CMAwIABA3D11VcDABYsWICPP/4YAFBcXIxZs2ahoKAAr732WsgPgo4kNzcX06ZNAwBcf/31zvMhxGvY293PPPMMGhsbcfPNN6OgoAALFy5sMabmz5+PXr16depzW7BgAQDg0ksvRUlJCc6ePdum+zl48CBSUlL8bps3bx5iYmIwcuRI9O/fH1dccQUAoKCgAOXl5e163kJKSkqr2/ykZfgl3UWMHz8excXFzr9fe+01/OY3vwmrYCsYvXr1cj4cbrnlFjz99NPYuHEj7rnnHjQ2NrZ4XU5ODvbs2YNjx445t509exbFxcXIz89H3759/T4EQt2X/eFkPx/7PkJdT4hbeeyxx5Cd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",
      "text/plain": [
       "<Figure size 500x250 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "covariance_test.runtime(1,D,D_lt,parameters)\n",
    "covariance_test.summary()\n",
    "covariance_test.plot()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Ising"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x250 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from utils.common import HubNetwork, binary_mcmc\n",
    "random.seed(23)\n",
    "np.random.seed(23)\n",
    "\n",
    "g = 2\n",
    "n = 50\n",
    "N_lt = [10*n]*g\n",
    "N_lt[1] = 20*n\n",
    "\n",
    "Sinv1 = HubNetwork(n, 0.99, 3, 0.01, \"binary\",[10,25,40])['Theta']\n",
    "np.fill_diagonal(Sinv1, 1)\n",
    "Sinv2 = Sinv1.copy()\n",
    "Sinv2[10,:] = 0\n",
    "Sinv2[:,10] = 0\n",
    "Sinv2[25,:] = 0\n",
    "Sinv2[:,25] = 0\n",
    "np.fill_diagonal(Sinv2, np.diag(Sinv1))\n",
    "Sinv = [Sinv1, Sinv2]\n",
    "\n",
    "fig, axs = plt.subplots(1, g, figsize=(2.5*g, 2.5))\n",
    "vmax = 0\n",
    "for i in range(g):\n",
    "    vmax = max(vmax, np.max(np.abs(Sinv[i]-np.diag(np.diag(Sinv[i])))))\n",
    "\n",
    "for i in range(g):\n",
    "    sns.heatmap(np.abs(Sinv[i]-np.diag(np.diag(Sinv[i]))), ax=axs[i], cmap=cmap, cbar=False, vmin=0, vmax=vmax)\n",
    "    axs[i].set_title('Ground Truth Precision (group '+str(i+1)+')', fontsize=7)\n",
    "    axs[i].axis('off')\n",
    "    \n",
    "plt.tight_layout()\n",
    "plt.show()\n",
    "\n",
    "D1 = binary_mcmc(N_lt[0], Sinv1, 10000, 100, trace=False)\n",
    "D2 = binary_mcmc(N_lt[1], Sinv2, 10000, 100, trace=False)\n",
    "\n",
    "D_lt = [D1, D2]\n",
    "D = np.zeros((N_lt[0]+N_lt[1], n), dtype=np.float64)\n",
    "D[:N_lt[0],:] = D1\n",
    "D[N_lt[0]:,:] = D2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "parameters = {'max_iter':100, 'outer_max_iter':100, 'step_size':1e-3, 'lam':0.1, 'lamm':0.1, 'rhom':1e5, 'tol':1e-5}\n",
    "ising_test = ModelTest(model_type='Ising',normalization=False,showfig=True)\n",
    "ising_test.group_graph(D,D_lt,parameters)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[1mGraph Learning\u001b[0m\n",
      "\u001b[4moverall global results:\u001b[0m 34.36319\n",
      "\u001b[4mdisparity error:\u001b[0m 0.000001 \n",
      "\n",
      "\u001b[1mObjective Fair Graph Learning\u001b[0m\n",
      "\u001b[4moverall global results:\u001b[0m 34.36168\n",
      "\u001b[4mdisparity error:\u001b[0m 0.000000\n",
      "\u001b[3mobjective improvement: 0.00151 (0.00439%)\u001b[0m\n",
      "\u001b[3mdisparity improvement: 0.000001 (99.99995%)\u001b[0m\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x250 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "ising_test.runtime(1,D,D_lt,parameters)\n",
    "ising_test.summary()\n",
    "ising_test.plot()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Graph_Learning",
   "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.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
