{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## $L_2$-norm loss model specification"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Starting from LPCA loss, we modify the factorization objective:\n",
    "$$\n",
    "\\begin{align*}\n",
    "L \n",
    "&=\n",
    "\\sum_{i=1}^{n}\n",
    "\\sum_{j=1}^{n}\n",
    "-\\log\\mathcal{l}\n",
    "\\left(\n",
    "    \\tilde{A}_{i,j}\\left[XY^\\top\\right]_{i,j}\n",
    "\\right)\n",
    "\\\\\n",
    "&\\rightarrow\n",
    "\\sum_{i=1}^{n}\n",
    "\\sum_{j=1}^{n}\n",
    "-\\log\\mathcal{l}\n",
    "\\left(\n",
    "    \\tilde{A}_{i,j}\\left[\\beta - ||x_i - y_j||_2\\right]\n",
    "\\right)\n",
    "\\end{align*}\n",
    "$$"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Test reconstruction"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "from graph_embeddings.models.L2Model import L2Model"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "**Load dataset**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [],
   "source": [
    "adj = torch.load('../data/adj_matrices/Cora.pt')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "**Load model and initialize**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [],
   "source": [
    "X, Y = torch.load('../models/metric-emb/X_Y.pt')\n",
    "beta = torch.load('../models/metric-emb/beta.pt')\n",
    "\n",
    "model = L2Model(X.shape[0], Y.shape[1], X.shape[1])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "**Test reconstruction**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [],
   "source": [
    "recon = model.reconstruct((X,Y,beta))\n",
    "recon_clipped = torch.clip(recon, min=0, max=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABLkAAAGXCAYAAABfpYIsAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAAA5LElEQVR4nO3deXhV9Z0/8E9CIFCWgAIJOxFpVcRqcUO02EqHp3WtqKNDKajjUnHBWq1MB61axaXTorauT13qUn9iq2JnrGVA6TBFtFg3VKQVK1UTREsCKCjk+/uD4cI1CAQTk3N5vZ7nPA8559x7v/nW3Hfv+56lKKWUAgAAAAAyrLi5BwAAAAAAn5aSCwAAAIDMU3IBAAAAkHlKLgAAAAAyT8kFAAAAQOYpuQAAAADIPCUXAAAAAJmn5AIAAAAg85RcAAAAAGSekgs+5oc//GEUFRVt02PvuOOOKCoqitdff71xB7WR119/PYqKiuKOO+5ostcAgM+CTAPYYFOfQ9asWRMXXHBB9OnTJ4qLi+Ooo46KiIgVK1bEv/7rv0ZFRUUUFRXFhAkTPvsBQwuk5KKgzJ8/P771rW9Fr169orS0NHr27BmjR4+O+fPnN/fQAGhE679UWL+UlJREr169Yty4cfHmm2829/Aa1Q033NDsJVBLGANA1nw8q9q2bRs9e/aMkSNHxnXXXRfLly/f4nPcdtttcc0118QxxxwTd955Z5x77rkREXHFFVfEHXfcEd/5znfirrvuijFjxjT1rwOZUJRSSs09CGgMv/nNb+KEE06IHXbYIU4++eSorKyM119/PX7xi1/Eu+++G/fdd19885vf3OLzrFmzJtasWRNt27Zt8BjWrl0bH330UZSWlm7z0WBb8vrrr0dlZWXcfvvtMW7cuCZ5DYCW7o477ogTTzwxLr300qisrIxVq1bFk08+GXfccUf0798/XnzxxW16H2+Jdt999+jatWs88cQTBTcGmQYUso9n1UcffRRVVVXxxBNPxPTp06Nv374xbdq02GOPPSJi059Djj/++Jg9e3b8/e9/z3vu/fffP0pKSmL27Nmf6e8ELV1Jcw8AGsNf//rXGDNmTOy0007xhz/8Ibp165bbds4558RBBx0UY8aMieeffz522mmnTT7HypUro3379lFSUhIlJdv2p9GqVato1arVNj0WgIb7+te/HnvvvXdERPzrv/5rdO3aNa666qqYNm1aHHfccc08us/e+iwDoOXYOKsiIiZOnBgzZ86Mww47LI444oh4+eWXo127dpv8HLJkyZLo3LlzvedcsmRJ7Lbbbo02xrq6uvjwww8L5gsitl9OV6QgXHPNNfH+++/HLbfckldwRUR07do1br755li5cmVcffXVEbHhfPeXXnop/uVf/iW6dOkSBx54YN62jX3wwQdx9tlnR9euXaNjx45xxBFHxJtvvhlFRUXxwx/+MLffpq7J1b9//zjssMNi9uzZse+++0bbtm1jp512il/+8pd5r/Hee+/F9773vRg8eHB06NAhOnXqFF//+tfjueeea8SZAihsBx10UESs+/JjvVdeeSWOOeaY2GGHHaJt27ax9957x7Rp0+o9dtmyZXHuuedG//79o7S0NHr37h3f/va3Y+nSpbl9lixZEieffHKUl5dH27Zt44tf/GLceeedec+z/jpTP/7xj+OWW26JAQMGRGlpaeyzzz7x9NNP5+1bVVUVJ554YvTu3TtKS0ujR48eceSRR+ZypH///jF//vyYNWtW7nSXgw8+OCI2ZM6sWbPijDPOiO7du0fv3r0jImLcuHHRv3//er/jJ1138u6774599903Pve5z0WXLl3iy1/+cvz+97/f4hjWz9uECROiT58+UVpaGjvvvHNcddVVUVdXV29+x40bF2VlZdG5c+cYO3ZsLFu2rN5YALYHX/3qV2PSpEnxt7/9Le6+++6IyH+PXp8ljz/+eMyfPz/3/vvEE09EUVFRLFq0KP7zP/8zt359bqxevTouvvji2HnnnaO0tDT69OkTF1xwQaxevTrv9YuKiuLMM8+Me+65JwYNGhSlpaXxu9/9LiIi3nzzzTjppJOivLw8SktLY9CgQXHbbbflPX79OO6///64/PLLo3fv3tG2bds45JBD4i9/+Uu933fu3LnxjW98I7p06RLt27ePPfbYI6699tq8fbY2r2FzHMlFQXjkkUeif//+uQ83H/flL385+vfvH//5n/+Zt/7YY4+NgQMHxhVXXBGbO3N33Lhxcf/998eYMWNi//33j1mzZsWhhx661eP7y1/+Esccc0ycfPLJMXbs2Ljtttti3LhxMWTIkBg0aFBERLz22mvx0EMPxbHHHhuVlZVRXV0dN998cwwfPjxeeuml6Nmz51a/HsD2av3/ye/SpUtErLtW47Bhw6JXr15x4YUXRvv27eP++++Po446Kn7961/nTmNfsWJFHHTQQfHyyy/HSSedFF/60pdi6dKlMW3atPj73/8eXbt2jQ8++CAOPvjg+Mtf/hJnnnlmVFZWxtSpU2PcuHGxbNmyOOecc/LGcu+998by5cvjtNNOi6Kiorj66qvj6KOPjtdeey1at24dERGjRo2K+fPnx1lnnRX9+/ePJUuWxPTp0+ONN96I/v37x5QpU+Kss86KDh06xA9+8IOIiCgvL897nTPOOCO6desWF110UaxcubLBc3bJJZfED3/4wzjggAPi0ksvjTZt2sTcuXNj5syZ8U//9E+bHcP7778fw4cPjzfffDNOO+206Nu3b/zxj3+MiRMnxttvvx1TpkyJiIiUUhx55JExe/bsOP3002PXXXeNBx98MMaOHdvg8QIUijFjxsS//du/xe9///s45ZRT8rZ169Yt7rrrrrj88stjxYoVMXny5IiI2HXXXeOuu+6Kc889N3r37h3nnXdebv+6uro44ogjYvbs2XHqqafGrrvuGi+88EL89Kc/jVdffTUeeuihvNeYOXNm3H///XHmmWdG165do3///lFdXR37779/rgTr1q1bPProo3HyySdHbW1tvQvcX3nllVFcXBzf+973oqamJq6++uoYPXp0zJ07N7fP9OnT47DDDosePXrEOeecExUVFfHyyy/Hb3/721x2bm1ewxYlyLhly5aliEhHHnnkZvc74ogjUkSk2tradPHFF6eISCeccEK9/dZvW2/evHkpItKECRPy9hs3blyKiHTxxRfn1t1+++0pItKiRYty6/r165ciIv3hD3/IrVuyZEkqLS1N5513Xm7dqlWr0tq1a/NeY9GiRam0tDRdeumleesiIt1+++2b/X0BCtn699v//u//Tu+8805avHhxeuCBB1K3bt1SaWlpWrx4cUoppUMOOSQNHjw4rVq1KvfYurq6dMABB6SBAwfm1l100UUpItJvfvObeq9VV1eXUkppypQpKSLS3Xffndv24YcfpqFDh6YOHTqk2tralNKG9+kdd9wxvffee7l9H3744RQR6ZFHHkkppfSPf/wjRUS65pprNvu7Dho0KA0fPvwT5+DAAw9Ma9asyds2duzY1K9fv3qP+XjGLVy4MBUXF6dvfvOb9TJo/e+9uTFcdtllqX379unVV1/NW3/hhRemVq1apTfeeCOllNJDDz2UIiJdffXVuX3WrFmTDjroIJkGFKz179NPP/30J+5TVlaW9tprr5RS/ffolFIaPnx4GjRoUL3H9evXLx166KF56+66665UXFyc/ud//idv/U033ZQiIv3v//5vbl1EpOLi4jR//vy8fU8++eTUo0ePtHTp0rz1xx9/fCorK0vvv/9+Simlxx9/PEVE2nXXXdPq1atz+1177bUpItILL7yQUlr3Xl9ZWZn69euX/vGPf+Q958Y5s7V5DVvidEUyb/1dSTp27LjZ/dZvr62tza07/fTTt/j86w/bPeOMM/LWn3XWWVs9xt122y3vKLNu3brFF77whXjttddy60pLS6O4eN2f5Nq1a+Pdd9+NDh06xBe+8IV45plntvq1ALYnI0aMiG7dukWfPn3imGOOifbt28e0adOid+/e8d5778XMmTPjuOOOi+XLl8fSpUtj6dKl8e6778bIkSNj4cKFuTsx/vrXv44vfvGLm/ymeP2pI//1X/8VFRUVccIJJ+S2tW7dOs4+++xYsWJFzJo1K+9x//zP/5w7oixiw6mU69/727VrF23atIknnngi/vGPf2zzHJxyyinbfD3Ihx56KOrq6uKiiy7KZdB6W3MDlalTp8ZBBx0UXbp0yc3v0qVLY8SIEbF27dr4wx/+EBHr5q6kpCS+853v5B7bqlWrBmUpQCHq0KHDVt1lcWtMnTo1dt1119hll13y3pO/+tWvRkTE448/nrf/8OHD867rlVKKX//613H44YdHSinvOUaOHBk1NTX1PpeceOKJ0aZNm9zPH8+6P//5z7Fo0aKYMGFCvWuLrc+ZhuQ1bInTFcm89eXVlsJhU2VYZWXlFp//b3/7WxQXF9fbd+edd97qMfbt27feui5duuR9qKmrq4trr702brjhhli0aFGsXbs2t23HHXfc6tcC2J78/Oc/j89//vNRU1MTt912W/zhD3+I0tLSiFh3qnhKKSZNmhSTJk3a5OOXLFkSvXr1ir/+9a8xatSozb7W3/72txg4cGC9MmjXXXfNbd/Yx9/71xde69/7S0tL46qrrorzzjsvysvLY//994/DDjssvv3tb0dFRcVWzsDWZdkn+etf/xrFxcXbfPHihQsXxvPPP1/vepjrLVmyJCLWzU2PHj2iQ4cOedu/8IUvbNPrAhSKFStWRPfu3RvluRYuXBgvv/zyFt+T1/t4frzzzjuxbNmyuOWWW+KWW27ZqufYUtatv0bm7rvv/onjbkhew5Youci8srKy6NGjRzz//POb3e/555+PXr16RadOnXLr2rVr19TDi4j4xG/Y00bXAbviiiti0qRJcdJJJ8Vll10WO+ywQxQXF8eECRPqXbwXgHX23Xff3B2rjjrqqDjwwAPjX/7lX2LBggW5987vfe97MXLkyE0+viFfWDTU1rz3T5gwIQ4//PB46KGH4rHHHotJkybF5MmTY+bMmbHXXntt1etsKss+6Sisjb9AaQx1dXXxta99LS644IJNbv/85z/fqK8HUEj+/ve/R01NTaNlUV1dXQwePDh+8pOfbHJ7nz598n7+eH6sz81vfetbn3jNxD322CPv563Jui1p7rymsCi5KAiHHXZY3HrrrTF79uzcXRI39j//8z/x+uuvx2mnndbg5+7Xr1/U1dXFokWLYuDAgbn1m7pryKfxwAMPxFe+8pX4xS9+kbd+2bJl0bVr10Z9LYBC1KpVq5g8eXJ85StfiZ/97Gdx0kknRcS6UwpHjBix2ccOGDAgXnzxxc3u069fv3j++eejrq4u72iuV155Jbd9WwwYMCDOO++8OO+882LhwoWx5557xn/8x3/k7ra1NacNflyXLl02eefCjx9tNmDAgKirq4uXXnop9txzz098vk8aw4ABA2LFihVbnN9+/frFjBkzYsWKFXlHcy1YsGCzjwMoZHfddVdExCcWOw01YMCAeO655+KQQw7Zpuzo1q1bdOzYMdauXbvF9/WGjCki4sUXX/zE59xpp50iYuvyGrbENbkoCOeff360a9cuTjvttHj33Xfztr333ntx+umnx+c+97k4//zzG/zc60PnhhtuyFt//fXXb/uAN6FVq1b1vvGYOnWq888BGuDggw+OfffdN6ZMmRKdOnWKgw8+OG6++eZ4++236+37zjvv5P49atSoeO655+LBBx+st9/69+ZvfOMbUVVVFf/v//2/3LY1a9bE9ddfHx06dIjhw4c3aKzvv/9+rFq1Km/dgAEDomPHjnm3em/fvv0mC6vNGTBgQNTU1OQd5fz222/X+/2OOuqoKC4ujksvvbTeUcMbZ9InjeG4446LOXPmxGOPPVZv27Jly2LNmjURsW7u1qxZEzfeeGNu+9q1axs9SwGyYubMmXHZZZdFZWVljB49ulGe87jjjos333wzbr311nrbPvjggy3egbdVq1YxatSo+PWvf73JL342zs2t9aUvfSkqKytjypQp9XJkfc507959q/MatsSRXBSEgQMHxp133hmjR4+OwYMHx8knnxyVlZXx+uuvxy9+8YtYunRp/OpXv8p9k9AQQ4YMiVGjRsWUKVPi3Xffjf333z9mzZoVr776akRs2zfsm3LYYYfFpZdeGieeeGIccMAB8cILL8Q999yT+2YDgK1z/vnnx7HHHht33HFH/PznP48DDzwwBg8eHKecckrstNNOUV1dHXPmzIm///3v8dxzz+Ue88ADD8Sxxx4bJ510UgwZMiTee++9mDZtWtx0003xxS9+MU499dS4+eabY9y4cTFv3rzo379/PPDAA/G///u/MWXKlC3eAOXjXn311TjkkEPiuOOOi9122y1KSkriwQcfjOrq6jj++ONz+w0ZMiRuvPHG+NGPfhQ777xzdO/ePXcR4U9y/PHHx/e///345je/GWeffXa8//77ceONN8bnP//5vIsG77zzzvGDH/wgLrvssjjooIPi6KOPjtLS0nj66aejZ8+euVvWf9IYzj///Jg2bVocdthhMW7cuBgyZEisXLkyXnjhhXjggQfi9ddfj65du8bhhx8ew4YNiwsvvDBef/312G233eI3v/lN1NTUNGjOALLo0UcfjVdeeSXWrFkT1dXVMXPmzJg+fXr069cvpk2bFm3btm2U1xkzZkzcf//9cfrpp8fjjz8ew4YNi7Vr18Yrr7wS999/fzz22GO5U/w/yZVXXhmPP/547LfffnHKKafEbrvtFu+9914888wz8d///d/x3nvvNWhMxcXFceONN8bhhx8ee+65Z5x44onRo0ePeOWVV2L+/Pm5L0m2Nq9hi5rpro7QJJ5//vl0wgknpB49eqTWrVunioqKdMIJJ+RuYbve+tvzvvPOO/WeY1O37l25cmUaP3582mGHHVKHDh3SUUcdlRYsWJAiIl155ZW5/dbfJnjRokW5dZu6vW9K624HvPHt2FetWpXOO++81KNHj9SuXbs0bNiwNGfOnHr7rb81vdutA9uzzd2Wfe3atWnAgAFpwIABac2aNemvf/1r+va3v50qKipS69atU69evdJhhx2WHnjggbzHvfvuu+nMM89MvXr1Sm3atEm9e/dOY8eOzbuNenV1dTrxxBNT165dU5s2bdLgwYPrvR+vf5++5ppr6o0tItLFF1+cUkpp6dKlafz48WmXXXZJ7du3T2VlZWm//fZL999/f95jqqqq0qGHHpo6duyYIiKXCVu6Nf3vf//7tPvuu6c2bdqkL3zhC+nuu+/eZMallNJtt92W9tprr1RaWpq6dOmShg8fnqZPn77FMaSU0vLly9PEiRPTzjvvnNq0aZO6du2aDjjggPTjH/84ffjhh3nzO2bMmNSpU6dUVlaWxowZk/785z/LNKBgrX+fXr+0adMmVVRUpK997Wvp2muvTbW1tXn7b+o9evjw4WnQoEH1nvuTPmN8+OGH6aqrrkqDBg3KvacPGTIkXXLJJammpia3X0Sk8ePHb3Lc1dXVafz48alPnz65z1SHHHJIuuWWW3L7PP744yki0tSpU/Me+0mfVWbPnp2+9rWvpY4dO6b27dunPfbYI11//fV5+2xtXsPmFKXUgCvCATnPPvts7LXXXnH33Xc32iHGAAAAwLZxTS7YCh988EG9dVOmTIni4uL48pe/3AwjAgAAADbmmlywFa6++uqYN29efOUrX4mSkpJ49NFH49FHH41TTz213q14AQAAgM+e0xVhK0yfPj0uueSSeOmll2LFihXRt2/fGDNmTPzgBz+IkhJdMQAAADQ3JRcAAAAAmeeaXAAAAABkXpOdZ/Xzn/88rrnmmqiqqoovfvGLcf3118e+++67xcfV1dXFW2+9FR07doyioqKmGh7AdiOlFMuXL4+ePXtGcXHhfLexrTkTIWsAGlshZo2cAWg5tjpnUhO47777Ups2bdJtt92W5s+fn0455ZTUuXPnVF1dvcXHLl68OEWExWKxWBp5Wbx4cVO85TeLT5MzKckai8ViaaqlULJGzlgsFkvLXLaUM01yTa799tsv9tlnn/jZz34WEeu+yejTp0+cddZZceGFF+btu3r16li9enXu55qamujbt28cGN+Ikmjd2EMD2O6siY9idvxXLFu2LMrKypp7OI2iITkTIWsAmlqhZY2cAWhZtjZnGv10xQ8//DDmzZsXEydOzK0rLi6OESNGxJw5c+rtP3ny5Ljkkks2MbDWUVIkEAA+tf/7KqNQTpdoaM5EyBqAJldAWSNnAFqgrcyZRj9hfunSpbF27dooLy/PW19eXh5VVVX19p84cWLU1NTklsWLFzf2kAAoIA3NmQhZA8DWkzMA2dVkF57fWqWlpVFaWtrcwwCggMkaAJqSnAFoGRr9SK6uXbtGq1atorq6Om99dXV1VFRUNPbLAbCdkTMANCU5A5BdjV5ytWnTJoYMGRIzZszIraurq4sZM2bE0KFDG/vlANjOyBkAmpKcAciuJjld8bvf/W6MHTs29t5779h3331jypQpsXLlyjjxxBOb4uUA2M7IGQCakpwByKYmKbn++Z//Od5555246KKLoqqqKvbcc8/43e9+V+/ijQCwLeQMAE1JzgBkU1FKKTX3IDZWW1sbZWVlcXAc6Xa7AI1gTfoonoiHo6amJjp16tTcw2kRZA1A45I1+eQMQOPa2pxp9rsrAmzOY289m/v3yJ57Nts4AChcsgYACkOjX3geAAAAAD5rSi4AAAAAMk/JBQAAAEDmuSYX0KK5NgoATU3WAEBhcCQXAAAAAJmn5AIAAAAg85yuCDQLt2sHoKnJGgDYvjiSCwAAAIDMU3IBAAAAkHlKLgAAAAAyzzW5gGbh2igANDVZAwDbF0dyAQAAAJB5Si4AAAAAMk/JBQAAAEDmKbkAAAAAyDwlFwAAAACZp+QCAAAAIPOUXAAAAABknpILAAAAgMxTcgEAAACQeUouAAAAADJPyQUAAABA5im5AAAAAMg8JRcAAAAAmafkAgAAACDzlFwAAAAAZJ6SCwAAAIDMK2nuAUDWPPbWs7l/j+y5Z7ONA4DCJWsAABrOkVwAAAAAZJ6SCwAAAIDMc7oiNJDTRgBoarIGAKDhHMkFAAAAQOYpuQAAAADIPKcrAhGRfyevCKfKAND4ZA0A0JQcyQUAAABA5im5AAAAAMg8JRcAAAAAmeeaXEBEuC4KAE1P1gAATcmRXAAAAABknpILAAAAgMxTcgEAAACQeUouAAAAADJPyQUAAABA5im5AAAAAMg8JRcAAAAAmafkAgAAACDzlFwAAAAAZJ6SCwAAAIDMU3IBAAAAkHlKLgAAAAAyT8kFAAAAQOYpuQAAAADIPCUXAAAAAJmn5AIAAAAg80qaewAANI7H3no27+eRPfdslnEAULiuef3JvJ/P779/M40EgEL0aT/TOJILAAAAgMxrUMk1efLk2GeffaJjx47RvXv3OOqoo2LBggV5+6xatSrGjx8fO+64Y3To0CFGjRoV1dXVjTpoAAqTnAGgqckagMLVoJJr1qxZMX78+HjyySdj+vTp8dFHH8U//dM/xcqVK3P7nHvuufHII4/E1KlTY9asWfHWW2/F0Ucf3egDByDfyJ575i1ZJGcAWrbz+++ft2SRrAFouT7tZ5qilFLa1hd/5513onv37jFr1qz48pe/HDU1NdGtW7e4995745hjjomIiFdeeSV23XXXmDNnTuy/f/0gXL16daxevTr3c21tbfTp0ycOjiOjpKj1tg4NgP+zJn0UT8TDUVNTE506dWru4TRIY+RMhKwBaGrbe9bIGYCmtbU586muyVVTUxMRETvssENERMybNy8++uijGDFiRG6fXXbZJfr27Rtz5szZ5HNMnjw5ysrKckufPn0+zZAAKCCNkTMRsgaAT+YzDUDh2OaSq66uLiZMmBDDhg2L3XffPSIiqqqqok2bNtG5c+e8fcvLy6OqqmqTzzNx4sSoqanJLYsXL97WIQFQQBorZyJkDQCb5jMNQGEp2dYHjh8/Pl588cWYPXv2pxpAaWlplJaWfqrnAODT3263pWmsnImQNQCNRdZsmpwBaBm26UiuM888M37729/G448/Hr17986tr6ioiA8//DCWLVuWt391dXVUVFR8qoECsP2QMwA0NVkDUHgaVHKllOLMM8+MBx98MGbOnBmVlZV524cMGRKtW7eOGTNm5NYtWLAg3njjjRg6dGjjjBiAgiVnAGhqsgagcDXodMXx48fHvffeGw8//HB07Ngxd056WVlZtGvXLsrKyuLkk0+O7373u7HDDjtEp06d4qyzzoqhQ4d+4h2vAGgcWT9lJELOALR0skbWALRkDSq5brzxxoiIOPjgg/PW33777TFu3LiIiPjpT38axcXFMWrUqFi9enWMHDkybrjhhkYZLACFTc4A0NRkDUDhKkoppeYexMZqa2ujrKwsDo4jo6SodXMPByDz1qSP4ol4OGpqaqJTp07NPZwWQdYANC5Zk0/OADSurc2ZbbrwPAAAAAC0JEouAAAAADJPyQUAAABA5im5AAAAAMi8Bt1dEdh6j731bO7fhXC7bQBaHlkDALCBI7kAAAAAyDwlFwAAAACZ53RFaCJOGwGgqckaAIANHMkFAAAAQOYpuQAAAADIPCUXAAAAAJnnmlxAROTfhj7CdV4AaHyyBgBoSo7kAgAAACDzlFwAAAAAZJ7TFYGIcMoIAE1P1gAATcmRXAAA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",
      "text/plain": [
       "<Figure size 1500x500 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# slice first 100\n",
    "_x,_y = 500,600\n",
    "adj_slice = adj[_x:_y, _x:_y]\n",
    "recon_clipped_slice = recon_clipped[_x:_y, _x:_y]\n",
    "\n",
    "# plot the results side by side \n",
    "import matplotlib.pyplot as plt \n",
    "fig, ax = plt.subplots(1, 3, figsize=(15, 5))\n",
    "ax[0].imshow(adj_slice.detach().cpu().numpy())\n",
    "ax[0].set_title('Original')\n",
    "ax[1].imshow(recon_clipped_slice.detach().cpu().numpy())\n",
    "ax[1].set_title('Reconstructed')\n",
    "ax[2].imshow((adj_slice - recon_clipped_slice).detach().cpu().numpy())\n",
    "ax[2].set_title('Difference')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "***Looks very promising, but plots above show one index where there is a difference.***"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## SVD"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "power-metoden til SVD for at kunne arbejde sparse på $2A - 11^\\top$"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "mlops",
   "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.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
