{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "33dba99a",
   "metadata": {},
   "outputs": [],
   "source": [
    "import networkx as nx \n",
    "import pickle \n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib\n",
    "\n",
    "bs = pickle.load(open(r'final_b.p', 'rb'))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "4b0d6264",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "dict_keys(['Amazon', 'Close Cliques', 'Dblp', 'Orkut', 'Patient Citation', 'Roadnet CA', 'Roadnet PA', 'Wikipedia Top Categories'])"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import numpy as np\n",
    "bs.keys()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "32438457",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(8, 1)\n"
     ]
    },
    {
     "ename": "TypeError",
     "evalue": "only integer scalar arrays can be converted to a scalar index",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m-------------------------------------------------------\u001b[0m",
      "\u001b[0;31mTypeError\u001b[0m             Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-23-e1f042b47d7b>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m     21\u001b[0m     \u001b[0mx\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0marray\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mrange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mlen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0my\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     22\u001b[0m     \u001b[0mmsk\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mp\u001b[0m\u001b[0;34m<\u001b[0m \u001b[0;36m3000\u001b[0m\u001b[0;34m/\u001b[0m\u001b[0mlen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0my\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 23\u001b[0;31m     \u001b[0max\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0midx\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mscatter\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mx\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mmsk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0my\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mmsk\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     24\u001b[0m     \u001b[0midx\u001b[0m \u001b[0;34m+=\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mTypeError\u001b[0m: only integer scalar arrays can be converted to a scalar index"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1440x720 with 8 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "matplotlib.use(\"pgf\")\n",
    "matplotlib.rcParams.update({\n",
    "    \"pgf.texsystem\": \"pdflatex\",\n",
    "    'font.family': 'serif',\n",
    "    'text.usetex': True,\n",
    "    'pgf.rcfonts': False,\n",
    "})\n",
    "\n",
    "datasets = bs.keys()\n",
    "\n",
    "fig, ax = plt.subplots(2, 4)\n",
    "fig.set_figheight(10)\n",
    "fig.set_figwidth(20)\n",
    "\n",
    "ax = np.array(ax).reshape(8)\n",
    "print(ax.shape)\n",
    "idx = int(0)\n",
    "for k in datasets:\n",
    "    y = bs[k]\n",
    "    p = np.random.uniform(0, 1, len(y))\n",
    "    x = np.array(range(len(y)))\n",
    "    msk = p< 3000/len(y)\n",
    "    ax[idx][0].scatter(x[msk], y[msk])\n",
    "    idx += 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "0b645386",
   "metadata": {},
   "outputs": [],
   "source": [
    "y = bs['Amazon']\n",
    "G = nx.Graph()\n",
    "with open('datasets_cleaned/com-amazon.ungraph.ready.txt', 'rb') as f:\n",
    "    lines = f.readlines()\n",
    "    n, m = [int(r) for r in lines[0].split()]\n",
    "    V = range(n)\n",
    "    E = []\n",
    "    G.add_nodes_from(V)\n",
    "    for i in range(m):\n",
    "        u,v  = [int(r) for r in lines[i+1].split()]\n",
    "        E.append((u,v))\n",
    "    \n",
    "    G.add_edges_from(E)\n",
    "    \n",
    "    for i in G:\n",
    "        G.nodes[i]['val'] = y[i]\n",
    "        "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "74873eb8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "42f843b1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "334863"
      ]
     },
     "execution_count": 29,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a7e8702b",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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.8.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
