{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "e8ebc7ac-ee66-4998-bac5-972b7b6d42a3",
   "metadata": {},
   "source": [
    "## Linear Separation in a Subspace"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e0238854-84cc-423e-bd71-d58098c6f9d0",
   "metadata": {},
   "source": [
    "## Result Plot"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "ba3db8a4-5993-4651-b208-0feae8b8263a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 360x180 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "\n",
    "y = [1,2,4,8,16,32,64]\n",
    "\n",
    "\n",
    "mean_accs = np.array([\n",
    "    [1.0000, 0.9933, 0.9817, 1.0000, 1.0000, 1.0000, 0.9983], #SKP\n",
    "    [1.0000, 0.9830, 0.8845, 0.8466, 0.8371, 0.8371, 0.8466], #FAGCN\n",
    "    [1.0000, 1.0000, 1.0000, 0.6967, 0.7050, 0.6983, 0.6783]  #GAT\n",
    "])\n",
    "\n",
    "std = np.array([\n",
    "    [0.0000, 0.0330, 0.0513, 0.0000, 0.0000, 0.0000, 0.0118],\n",
    "    [0.0000, 0.0495, 0.0411, 0.0309, 0.0176, 0.0176, 0.0309],\n",
    "    [0.0000, 0.0000, 0.0000, 0.0438, 0.0564, 0.0692, 0.0790]  #GAT\n",
    "])\n",
    "    \n",
    "plt.figure(figsize=(5,2.5))\n",
    "plt.plot(y, mean_accs[0], color='#73D055', label=\"SKP\")\n",
    "plt.plot(y, mean_accs[1], color='#1F968B', label=\"FAGCN\")\n",
    "plt.plot(y, mean_accs[2], color='#440154', label=\"GAT\")\n",
    "\n",
    "plt.fill_between(y, mean_accs[0] - std[0], mean_accs[0] + std[0], alpha=0.1, color='#73D055')\n",
    "plt.fill_between(y, mean_accs[1] - std[1], mean_accs[1] + std[1], alpha=0.1, color='#1F968B')\n",
    "plt.fill_between(y, mean_accs[2] - std[2], mean_accs[2] + std[2], alpha=0.1, color='#440154')\n",
    "\n",
    "plt.ylim([0.4,1.05])\n",
    "plt.xscale('log')\n",
    "plt.xticks([1,2,4,8,16,32,64],[1,2,4,8,16,32,64])\n",
    "plt.ylabel('Accuracy')\n",
    "plt.xlabel('Number of layers')\n",
    "plt.legend()\n",
    "\n",
    "plt.savefig('er_results.svg',bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2bcb6f93-227a-4b86-89f0-58ce85e878c5",
   "metadata": {},
   "source": [
    "## Loss curves"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "c4759b62-9abc-4021-8eb4-054fc2fa0c8f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAUoAAAC1CAYAAAA5mrZ9AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8qNh9FAAAACXBIWXMAAAsTAAALEwEAmpwYAAAml0lEQVR4nO3deXgd1Xn48e97d+2yNi/yDjjGBltgs6SB2FDiJNACyRPK1uDy0PKDkjT9tQkFEhJoIb+QkJKkAVJKEyALbnhSMKGE5QnGSUMA28RgwDjYIBtZXmVr113n/f0xc6+vZElXtnV1tbyf55lnZs45M3OObL06d2buOaKqGGOMGZiv0BUwxpjRzgKlMcbkYIHSGGNysEBpjDE5WKA0xpgcLFAaY0wOgUJX4EjV1NTo7NmzC10NY8w4s2HDhv2qWttf3pgLlLNnz2b9+vWFroYxZpwRke0D5dlHb2OMycECpTHG5JC3QCkiPxSRvSLy5gD5IiLfE5GtIvKGiJyar7oYY8yxyOc9yoeA7wOPDJD/SeAEbzkDuN9bj3k/e/t1PlRVy5Ip00bsmolEgqamJqLR6Ihd05ixKBKJMH36dILB4JCPyVugVNXfiMjsQYpcBDyi7qgcL4tIpYhMVdVd+arTSLll7fMANF7/xRG7ZlNTE2VlZcyePRsRGbHrGjOWqCotLS00NTUxZ86cIR9XyHuU9cAHWftNXpo5CtFolOrqaguSxgxCRKiurj7iT16FDJT9/Ub3O+abiFwrIutFZP2+ffvyXK2xy4KkMbkdze9JIQNlEzAja3860NxfQVV9QFWXqurS2tp+3wc1o8Cdd97JwoULWbRoEQ0NDbzyyissX748895rY2MjJ5xwAs8++ywvvvgiFRUVnHLKKZx44oncfvvtBa798NqzZw9XXHEFc+fOZcmSJXz4wx/m8ccfz+R/4QtfoL6+Hsdx2LRpEw0NDTQ0NFBVVcWcOXNoaGjgvPPOK2ALho/f78+0r6GhgcbGRgDuueceIpEIbW1tvco/88wznH766cyfP5+GhgYuvfRSduzYkcm/++67mT9/PieddBKLFy/mkUfcxyDLly9n6dKlmXLr169n+fLlw9MIVc3bAswG3hwg7wLgV7g9yzOBV4dyziVLluhoN+u+b+ms+741otd8++23R/R6fb300kt65plnajQaVVXVffv26c6dO3XZsmW6bt06/eCDD3TevHm6evVqVVVds2aNXnDBBaqq2tnZqccff7yuX7++YPUfTo7j6Jlnnqn3339/Jq2xsVG/973vqapqKpXSGTNm6BlnnKFr1qzpdezKlSv1scceG8nq5l1JSUm/6aeddpqeddZZ+qMf/SiTtmnTJj3++ON7/X9evXq1rl27VlVV77//fl2xYoW2tbWpqmpra6s+9NBDqqq6bNkynTFjhj799NOqqrpu3TpdtmxZv9fu7/cFWK8DxJ18vh70KPB74EMi0iQi14jIdSJynVfkaeA9YCvwH8Df5qsuJv927dpFTU0N4XAYgJqaGqZNc5/67969mxUrVnDHHXdw4YUXHnZsSUkJS5YsYdu2bSNa53x54YUXCIVCXHfddZm0WbNm8fnPfx6ANWvWcNJJJ3H99dfz6KOPFqqaBbVt2zY6Ozu54447ev0M7rrrLm655RZOPPHETNqFF17IRz/6UQC+/vWvc99991FeXg5ARUUFK1euzJT90pe+xB133DHs9c3nU+/Lc+QrcEO+rj+Rrd75EDt7Gof1nPVFs7mo/q8GzF+xYgX//M//zLx58zjvvPO49NJLWbZsGQBXXXUVd9xxB5dcckm/x7a0tPDyyy9z6623DmudAe77+x+x7fXGYT3ncYtn87ffuXrA/LfeeotTTx34teBHH32Uyy+/nIsuuohbbrmFRCJxRK+qHK3b//cF3m7ZO6znXFBdx9fOOnfQMj09PTQ0NAAwZ84cHn/88czP4Oyzz2bLli3s3buXuro63nrrLb74xf7fFuno6KCjo4PjjjtuwGulb3GsWbOGsrKyo25XX/bNHDMsSktL2bBhAw888AC1tbVceumlPPTQQwCcd955/PjHP6a7u7vXMb/97W855ZRTWLFiBTfddBMLFy4sQM3z74YbbmDx4sWcdtppxONxnn76aS6++GLKy8s544wzeO655wpdxbwqKipi48aNbNy4MXOfdtWqVVx22WX4fD4+/elP89hjjx12XEtLCw0NDcybN4+7774bVR3Sg5ivfOUrw96rHHODYpjcBuv55ZPf72f58uUsX76ck08+mYcffhiAG2+8kZ/85CdccsklrF69mkDA/W939tln89RTT+W1ToP1/PJl4cKF/OIXv8js33vvvezfv5+lS5fyzDPP0NbWxsknnwxAd3c3xcXFXHDBBXmv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\n",
      "text/plain": [
       "<Figure size 360x180 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "skp_losses = np.loadtxt('./results/loss_skp.txt')\n",
    "gat_losses = np.loadtxt('./results/loss_gat.txt')\n",
    "fagcn_losses = np.loadtxt('./results/loss_fagcn.txt')\n",
    "y = np.arange(5001)\n",
    "\n",
    "plt.figure(figsize=(5,2.5))\n",
    "plt.plot(y, skp_losses, label='SKP', color='#73D055')\n",
    "plt.plot(y, gat_losses, label='GAT', color='#440154')\n",
    "plt.plot(y, fagcn_losses, label='FAGCN', color='#1F968B')\n",
    "plt.legend(ncol=3)\n",
    "plt.xlabel('Number of steps')\n",
    "plt.ylabel('Loss')\n",
    "plt.savefig('er_loss_8.svg',bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "3416d177-73cb-47b2-8bf7-be6da13aff2f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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Taf6oy4uLm5rncx4PObb3/621zfcNXNp5vfffz+TyYS33nqLz372s9vyntcYaiK50eHurt/85jf5nd/5Hd5//3263S5//+//fY4ePcq9997L3r17p6yNSw07bxYX0k02Ov56tUzOQtlKNMhFy5y+8eKLLzKZTPj85z/vhdHbbrvtenZTLgXX/MWoiWSbkGUZX/va13j00UcBvM7yne98h06nw9GjR3n88cc5evTouvkM64WdnV7iktM2wkYFjbNETtZGjFx+SjUTt9lsorXmww8/5LnnnuPFF1/klVdeodVq8dhjj/H000/zxBNPTI2DqLEurvmLUxPJZYbWmjNnznidxUUgHnroIe8OrZdhuR45uLBzu932iV+9Xs+ntzvSuVzl+1mWsby8zI9+9CNeeOEFfvM3f5N+v8/Bgwf5G3/jb/BTP/VTPPLII7Tb7W1/7+scNZHU2DoGgwEvvfQSzzzzDM899xynT5/m/vvv95XO99xzj7cgXLHhih1z6Zppg8kn2bNnD7t3754p7HwhJEnCd77zHV8Re/z4ce69916efPJJjh49ShAEvPzyy/zCL/zCZe8Rcx2jJpIasyPLMl577TW+9a1v8Rd/8Rd873vfo9VqEUURX/rSl3jggQfYvXv3eQln64WdnVVyKVmlrur6pZde4rnnnuOll15iMBjwuc99zqea33777ZddGL4BURNJje3FBx98wK/92q9x++23UxQFP/jBD3jttddYXFz0Osujjz66bkatCzu7ZDnXZNsRy9oEMq01J0+e5LnnnuP555/n29/+NmEYcvToUZ566imefPJJ9u3bV+sblx/X/AWuieQagOvU9cwzz/Dss89y7NgxlFI8/PDD3h06cODAeRt+vZT2b3zjG3z00Uf0ej1OnDjBgQMHvLXhCKrGFUdNJDWuPFzv0BdffNHrLK63hiOWO++8kzzPee2117y+8e6773LPPffQarUYDAYcPHiQf/tv/+3VPp0aNZHU2ClI09Q32HZWy/z8PI899phP/Frbvb/GjkFNJDV2JrIsQwhxQ8ydvQ5QE0mNGjVmxjVPJLWdW6NGjZlRE0mNGjVmRk0kNWrUmBk1kdSoUWNm1ERSo0aNmVETSY0aNWZGTSQ1atSYGTWR1KhRY2bURFKjRo2ZURNJjRo1ZsY1RyRf/OIXWVxc5K/9tb92tZdS4zrBa6+9xmOPPcanPvUpHnzwQX73d3/3ai/pmsM1V2vzJ3/yJ4xGI37jN36Db3zjG1d7OTWuA7z11lsIIbjrrrs4ceIEDz30EG+88QaLi4tXagl1rc3lwssvv8yDDz7IZDJhOBzyqU99ih/84Af85E/+JPPz81d7eTWuUaz3vUrTlLvuuguAm2++mf3793PmzJmrvNJrCzu2xvzhhx/mr//1v84//+f/nPF4zM/93M9x//33X+1l1bjGcbHv1bFjx0jTlE984hNXcZXXHna0a5OmKQ8//DDNZpPnn3/ed0n/8z//c37t136tdm1qXBI2+l59/PHH/MRP/ARf/epXOXr06JVcUu3aXE4sLS0xGAzo9/tMJpOrvZwa1wnW+16trq7yV//qX+VXfuVXrjSJXBfY0UTyD/7BP+Bf/It/wc/+7M/yT//pP73ay6lxnWDt9ypNU37mZ36Gn//5n+dv/a2/dbWXd21Ca32hn6uGr371q/pnfuZntNZa53muH3nkEf0nf/In+sknn9R79+7VzWZTHzp0SP/hH/7h1VxmjWsM632vvvrVr+owDPWnP/1p//Pqq69eyWVdbB/u+J8drZHUqHGDoNZIatSoUaMmkho1asyMmkhq1KgxM2oiqVGjxsyoiaRGjRozoyaSGjVqzIyaSGrUqDEzaiKpUaPGzKiJpEaNGjOjJpIaNWrMjJpIatSoMTNqIqlRo8bMqImkRo0aM6Mmkho1asyMmkhq1KgxM2oiqVGjxsy4WBf5a77hSo0aNS4/aoukRo0aM6Mmkho1asyMmkhq1KgxM2oiqVGjxsyoiaRGjRozoyaSGjVqzIz/H4MMzluM5o3EAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "from mpl_toolkits.mplot3d import Axes3D\n",
    "\n",
    "def plot_3D_array_slices(array):\n",
    "    min_val = array.min()\n",
    "    max_val = array.max()\n",
    "    n_x, n_y, n_z = array.shape\n",
    "    colormap = plt.cm.YlOrRd\n",
    "\n",
    "    Y, Z = np.mgrid[0:n_y, 0:n_z]\n",
    "    X = n_x//2 * np.ones((n_y, n_z))\n",
    "    fig = plt.figure()\n",
    "    ax = fig.add_subplot(111, projection='3d')\n",
    "    ax.plot_surface(X, Y, Z, rstride=1, cstride=1, shade=True, alpha=0.8, zorder=1, color='#440154')#, facecolors=colormap((z_cut-min_val)/(max_val-min_val))\n",
    "    \n",
    "    ax.plot([50],[20],[40], '.', c='#404788', markersize=20, label='top', zorder=4)\n",
    "    ax.plot([50],[70],[70], '.', c='#238A8D', markersize=20, label='top', zorder=4)\n",
    "    ax.plot([50],[30],[80], '.', c='#55C667', markersize=20, label='top', zorder=4)\n",
    "    ax.plot([50],[80],[20], '.', c='#FDE725', markersize=20, label='top', zorder=4)\n",
    "    \n",
    "    ax.set_xlabel('x1')\n",
    "    ax.set_ylabel('x2')\n",
    "    ax.set_zlabel('x3')\n",
    "    ax.set_xticklabels([])\n",
    "    ax.set_yticklabels([])\n",
    "    ax.set_zticklabels([])\n",
    "    \n",
    "    ax.view_init(elev=10, azim=-45)\n",
    "    plt.savefig(f'subspace.svg', transparent = True, bbox_inches='tight')\n",
    "    plt.show()\n",
    "\n",
    "\n",
    "n_pts = 100\n",
    "r_square = (np.mgrid[-1:1:1j*n_pts, -1:1:1j*n_pts, -1:1:1j*n_pts]**2).sum(0)\n",
    "plot_3D_array_slices(r_square)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
