{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "import numpy\n",
    "import matplotlib.pyplot as plt\n",
    "import torch\n",
    "import networkx as nx\n",
    "\n",
    "%matplotlib inline"
   ]
  },
  {
   "cell_type": "raw",
   "metadata": {
    "jupyter": {
     "outputs_hidden": false
    },
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "source": [
    "with open('generalized_graph_learning/data/debug/last_eval_graphs.pickle', 'rb') as f:\n",
    "    inf_train_graphs, val_graphs, test_graphs = pickle.load(f)\n",
    "\n",
    "with open('generalized_graph_learning/data/debug/last_training_graphs.pickle', 'rb') as f:\n",
    "    train_graphs = pickle.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "ename": "FileNotFoundError",
     "evalue": "[Errno 2] No such file or directory: 'generalized_graph_learning/data/debug/graphs_C_non_smooth.pickle'",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mFileNotFoundError\u001b[0m                         Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-2-34135f81c466>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[0;32m----> 1\u001b[0;31m \u001b[0;32mwith\u001b[0m \u001b[0mopen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m'generalized_graph_learning/data/debug/graphs_C_non_smooth.pickle'\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m'rb'\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mas\u001b[0m \u001b[0mf\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m      2\u001b[0m     \u001b[0minf_train_graphs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mval_graphs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtest_graphs\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mpickle\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mload\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mf\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mFileNotFoundError\u001b[0m: [Errno 2] No such file or directory: 'generalized_graph_learning/data/debug/graphs_C_non_smooth.pickle'"
     ]
    }
   ],
   "source": [
    "with open('generalized_graph_learning/data/debug/graphs_C_non_smooth.pickle', 'rb') as f:\n",
    "    inf_train_graphs, val_graphs, test_graphs = pickle.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {
    "collapsed": false,
    "jupyter": {
     "outputs_hidden": false
    },
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": [
    "def mask_diagonal_and_sigmoid(A):\n",
    "    mask = torch.eye(A.shape[1], dtype=bool, device=A.device).repeat(A.shape[0], 1, 1)\n",
    "    return torch.sigmoid(A - mask*100000000)\n",
    "    #return A.masked_select(mask).view(A.shape[0], A.shape[1], A.shape[2])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {
    "collapsed": false,
    "jupyter": {
     "outputs_hidden": false
    },
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.colorbar.Colorbar at 0x7fbec64bf160>"
      ]
     },
     "execution_count": 37,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 432x288 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 288x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 432x288 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 288x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "A_pred, A = test_graphs[0]\n",
    "A_pred, A = mask_diagonal_and_sigmoid(A_pred)[0].cpu().detach().numpy(), A[0].cpu().numpy()\n",
    "\n",
    "\n",
    "plt.figure()\n",
    "plt.matshow(A)\n",
    "plt.colorbar()\n",
    "\n",
    "plt.figure()\n",
    "plt.matshow(A_pred)\n",
    "plt.colorbar()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.6.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
