{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 147,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np  \n",
    "import pandas as pd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 148,
   "metadata": {},
   "outputs": [],
   "source": [
    "# https://archive.ics.uci.edu/ml/datasets/Activities+of+Daily+Living+%28ADLs%29+Recognition+Using+Binary+Sensors#\n",
    "def get_adl(path):\n",
    "    with open(path, 'r') as f:\n",
    "        lines = f.readlines()\n",
    "    \n",
    "    df = pd.DataFrame(columns=['alarm_id','start_timestamp','device_id'])\n",
    "    \n",
    "    for l in lines[2:]: #ignore header and spacer line\n",
    "        l = l.strip().split(\"\\t\")\n",
    "        l = list(filter(lambda x:x !='', l))\n",
    "        new_row_start = {'alarm_id': l[2] + \"_start\", 'start_timestamp': l[0].strip(), 'device_id': 0}\n",
    "        new_row_end = {'alarm_id': l[2] + \"_end\", 'start_timestamp': l[1].strip(), 'device_id': 0}\n",
    "        new_df = pd.DataFrame([new_row_start, new_row_end], index=[0,1])\n",
    "        df = pd.concat([df, new_df])\n",
    "    \n",
    "    cat_codes = df[\"alarm_id\"].astype('category')\n",
    "    df['alarm_id'] = cat_codes.cat.codes\n",
    "\n",
    "    df['start_timestamp'] = pd.to_datetime(df['start_timestamp']).astype(np.int64) // 10**9\n",
    "    df['start_timestamp'] = df['start_timestamp'] - df['start_timestamp'].min()\n",
    "    \n",
    "    return df,cat_codes"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 149,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>alarm_id</th>\n",
       "      <th>start_timestamp</th>\n",
       "      <th>device_id</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>19</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>18</td>\n",
       "      <td>11339</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>19</td>\n",
       "      <td>11399</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>18</td>\n",
       "      <td>12599</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>7</td>\n",
       "      <td>12840</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>18</td>\n",
       "      <td>1811279</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>7</td>\n",
       "      <td>1811700</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>6</td>\n",
       "      <td>1811759</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>19</td>\n",
       "      <td>1812420</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>18</td>\n",
       "      <td>1828199</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>986 rows × 3 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "    alarm_id  start_timestamp device_id\n",
       "0         19                0         0\n",
       "1         18            11339         0\n",
       "0         19            11399         0\n",
       "1         18            12599         0\n",
       "0          7            12840         0\n",
       "..       ...              ...       ...\n",
       "1         18          1811279         0\n",
       "0          7          1811700         0\n",
       "1          6          1811759         0\n",
       "0         19          1812420         0\n",
       "1         18          1828199         0\n",
       "\n",
       "[986 rows x 3 columns]"
      ]
     },
     "execution_count": 149,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df, cat_codes = get_adl(\"data/hopper/ordonez/OrdonezB_ADLs.txt\")\n",
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 150,
   "metadata": {},
   "outputs": [],
   "source": [
    "df.to_csv('data/hopper/ordonez/OrdonezA_ADLs.csv', index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 157,
   "metadata": {},
   "outputs": [],
   "source": [
    "adjacency = np.load(\"output/ordzoneA.npy\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 158,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{0: ' \\nend',\n",
       " 1: ' \\nstart',\n",
       " 2: 'Breakfast\\nend',\n",
       " 3: 'Breakfast\\nstart',\n",
       " 4: 'Dinner\\nend',\n",
       " 5: 'Dinner\\nstart',\n",
       " 6: 'Grooming\\nend',\n",
       " 7: 'Grooming\\nstart',\n",
       " 8: 'Leaving\\nend',\n",
       " 9: 'Leaving\\nstart',\n",
       " 10: 'Lunch\\nend',\n",
       " 11: 'Lunch\\nstart',\n",
       " 12: 'Showering\\nend',\n",
       " 13: 'Showering\\nstart',\n",
       " 14: 'Sleeping\\nend',\n",
       " 15: 'Sleeping\\nstart',\n",
       " 16: 'Snack\\nend',\n",
       " 17: 'Snack\\nstart',\n",
       " 18: 'Spare\\nTime/TV\\nend',\n",
       " 19: 'Spare\\nTime/TV\\nstart',\n",
       " 20: 'Toileting\\nend',\n",
       " 21: 'Toileting\\nstart'}"
      ]
     },
     "execution_count": 158,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "names"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 159,
   "metadata": {},
   "outputs": [
    {
     "ename": "NetworkXError",
     "evalue": "Node 'Dinner\\nend' has no position.",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyError\u001b[0m                                  Traceback (most recent call last)",
      "\u001b[0;32m~/opt/anaconda3/lib/python3.9/site-packages/networkx/drawing/nx_pylab.py\u001b[0m in \u001b[0;36mdraw_networkx_nodes\u001b[0;34m(G, pos, nodelist, node_size, node_color, node_shape, alpha, cmap, vmin, vmax, ax, linewidths, edgecolors, label)\u001b[0m\n\u001b[1;32m    455\u001b[0m     \u001b[0;32mtry\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 456\u001b[0;31m         \u001b[0mxy\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0masarray\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mpos\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mv\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mv\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mnodelist\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    457\u001b[0m     \u001b[0;32mexcept\u001b[0m \u001b[0mKeyError\u001b[0m \u001b[0;32mas\u001b[0m \u001b[0me\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/opt/anaconda3/lib/python3.9/site-packages/networkx/drawing/nx_pylab.py\u001b[0m in \u001b[0;36m<listcomp>\u001b[0;34m(.0)\u001b[0m\n\u001b[1;32m    455\u001b[0m     \u001b[0;32mtry\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 456\u001b[0;31m         \u001b[0mxy\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0masarray\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mpos\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mv\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mv\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mnodelist\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    457\u001b[0m     \u001b[0;32mexcept\u001b[0m \u001b[0mKeyError\u001b[0m \u001b[0;32mas\u001b[0m \u001b[0me\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mKeyError\u001b[0m: 'Dinner\\nend'",
      "\nThe above exception was the direct cause of the following exception:\n",
      "\u001b[0;31mNetworkXError\u001b[0m                             Traceback (most recent call last)",
      "\u001b[0;32m/var/folders/vb/598bd39x0lj3t80ztvlt81z40000gn/T/ipykernel_17988/2463309845.py\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m     12\u001b[0m \u001b[0;31m# make the notes bigger\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     13\u001b[0m \u001b[0;31m# pos = nx.circular_layout(G)  # Increase the scale value to increase the space between nodes\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 14\u001b[0;31m \u001b[0mnx\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdraw\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mG\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mwith_labels\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mTrue\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0marrowsize\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m20\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mpos\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mpos\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     15\u001b[0m \u001b[0mplt\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mshow\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[0;32m~/opt/anaconda3/lib/python3.9/site-packages/networkx/drawing/nx_pylab.py\u001b[0m in \u001b[0;36mdraw\u001b[0;34m(G, pos, ax, **kwds)\u001b[0m\n\u001b[1;32m    121\u001b[0m         \u001b[0mkwds\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m\"with_labels\"\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m\"labels\"\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mkwds\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    122\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 123\u001b[0;31m     \u001b[0mdraw_networkx\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mG\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mpos\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mpos\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0max\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0max\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwds\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    124\u001b[0m     \u001b[0max\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mset_axis_off\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    125\u001b[0m     \u001b[0mplt\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdraw_if_interactive\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[0;32m~/opt/anaconda3/lib/python3.9/site-packages/networkx/drawing/nx_pylab.py\u001b[0m in \u001b[0;36mdraw_networkx\u001b[0;34m(G, pos, arrows, with_labels, **kwds)\u001b[0m\n\u001b[1;32m    333\u001b[0m         \u001b[0mpos\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnx\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdrawing\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mspring_layout\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mG\u001b[0m\u001b[0;34m)\u001b[0m  \u001b[0;31m# default to spring layout\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    334\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 335\u001b[0;31m     \u001b[0mdraw_networkx_nodes\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mG\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mpos\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mnode_kwds\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    336\u001b[0m     \u001b[0mdraw_networkx_edges\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mG\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mpos\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0marrows\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0marrows\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0medge_kwds\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    337\u001b[0m     \u001b[0;32mif\u001b[0m \u001b[0mwith_labels\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/opt/anaconda3/lib/python3.9/site-packages/networkx/drawing/nx_pylab.py\u001b[0m in \u001b[0;36mdraw_networkx_nodes\u001b[0;34m(G, pos, nodelist, node_size, node_color, node_shape, alpha, cmap, vmin, vmax, ax, linewidths, edgecolors, label)\u001b[0m\n\u001b[1;32m    456\u001b[0m         \u001b[0mxy\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0masarray\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mpos\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mv\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mv\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mnodelist\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    457\u001b[0m     \u001b[0;32mexcept\u001b[0m \u001b[0mKeyError\u001b[0m \u001b[0;32mas\u001b[0m \u001b[0me\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 458\u001b[0;31m         \u001b[0;32mraise\u001b[0m \u001b[0mnx\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mNetworkXError\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34mf\"Node {e} has no position.\"\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mfrom\u001b[0m \u001b[0me\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    459\u001b[0m     \u001b[0;32mexcept\u001b[0m \u001b[0mValueError\u001b[0m \u001b[0;32mas\u001b[0m \u001b[0me\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    460\u001b[0m         \u001b[0;32mraise\u001b[0m \u001b[0mnx\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mNetworkXError\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m\"Bad value in node positions.\"\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mfrom\u001b[0m \u001b[0me\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mNetworkXError\u001b[0m: Node 'Dinner\\nend' has no position."
     ]
    },
    {
     "data": {
      "image/png": "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AAApCF8AAFIQvgAApCB8AQBIQfgCAJCC8AUAIAXhCwBACsIXAIAUhC8AACkIXwAAUhC+AACkIHwBAEhB+AIAkILwBQAgBeELAEAKwhcAgBSELwAAKQhfAABSEL4AAKQgfAEASEH4AgCQgvAFACAF4QsAQArCFwCAFIQvAAApCF8AAFIQvgAApCB8AQBIYVThu27duqivr4+qqqpoaGiIbdu2nXLuc889F9dff318/OMfj+rq6pg/f3784he/GPWGAQBgNEoO382bN8fy5ctj9erV0dnZGQsXLoxFixZFV1fXiPNffvnluP7666O9vT127doVX/rSl+Lmm2+Ozs7Os948AACcqbKiKIpSFsybNy/mzJkT69evHxybNWtWLF68ONra2s7oPT772c/GkiVL4v777z+j+f39/VFTUxN9fX1RXV1dynYBALgAjUf/lXTF9+jRo7Fr165obm4eMt7c3Bzbt28/o/c4ceJEHDlyJC699NJTzhkYGIj+/v4hLwAAOBslhW9vb28cP348amtrh4zX1tZGT0/PGb3HD37wg3j33XfjlltuOeWctra2qKmpGXzNmDGjlG0CAMAwo/rltrKysiE/F0UxbGwkTz31VHz3u9+NzZs3x2WXXXbKeatWrYq+vr7B14EDB0azTQAAGFReyuQpU6bExIkTh13dPXTo0LCrwH9s8+bNcdddd8XTTz8d11133WnnVlZWRmVlZSlbAwCA0yrpim9FRUU0NDRER0fHkPGOjo5oamo65bqnnnoq7rjjjnjyySfjpptuGt1OAQDgLJR0xTciorW1NW677bZobGyM+fPnx09/+tPo6uqKlpaWiPjgNoXf/e538fOf/zwiPojepUuXxg9/+MP4whe+MHi1+KKLLoqampox/CoAAHBqJYfvkiVL4vDhw7F27dro7u6O2bNnR3t7e9TV1UVERHd395Bn+v7kJz+JY8eOxTe/+c345je/OTh+++23xxNPPHH23wAAAM5Ayc/xPR88xxcAIJfz/hxfAAC4UAlfAABSEL4AAKQgfAEASEH4AgCQgvAFACAF4QsAQArCFwCAFIQvAAApCF8AAFIQvgAApCB8AQBIQfgCAJCC8AUAIAXhCwBACsIXAIAUhC8AACkIXwAAUhC+AACkIHwBAEhB+AIAkILwBQAgBeELAEAKwhcAgBSELwAAKQhfAABSEL4AAKQgfAEASEH4AgCQgvAFACAF4QsAQArCFwCAFIQvAAApCF8AAFIQvgAApCB8AQBIQfgCAJCC8AUAIAXhCwBACsIXAIAUhC8AACkIXwAAUhC+AACkIHwBAEhB+AIAkILwBQAgBeELAEAKwhcAgBSELwAAKQhfAABSEL4AAKQgfAEASEH4AgCQgvAFACAF4QsAQArCFwCAFIQvAAApCF8AAFIQvgAApCB8AQBIQfgCAJCC8AUAIAXhCwBACsIXAIAUhC8AACkIXwAAUhC+AACkIHwBAEhB+AIAkILwBQAgBeELAEAKwhcAgBSELwAAKQhfAABSEL4AAKQgfAEASEH4AgCQgvAFACAF4QsAQArCFwCAFIQvAAApCF8AAFIQvgAApCB8AQBIQfgCAJDCqMJ33bp1UV9fH1VVVdHQ0BDbtm077fytW7dGQ0NDVFVVxcyZM+PRRx8d1WYBAGC0Sg7fzZs3x/Lly2P16tXR2dkZCxcujEWLFkVXV9eI8/fv3x833nhjLFy4MDo7O+M73/lOLFu2LJ599tmz3jwAAJypsqIoilIWzJs3L+bMmRPr168fHJs1a1YsXrw42trahs3/9re/HS+++GLs3bt3cKylpSV+9atfxY4dO87oM/v7+6Ompib6+vqiurq6lO0CAHABGo/+Ky9l8tGjR2PXrl2xcuXKIePNzc2xffv2Edfs2LEjmpubh4zdcMMNsWHDhnj//fdj0qRJw9YMDAzEwMDA4M99fX0R8cF/AAAA/Ok72X0lXqM9rZLCt7e3N44fPx61tbVDxmtra6Onp2fENT09PSPOP3bsWPT29sbUqVOHrWlra4s1a9YMG58xY0Yp2wUA4AJ3+PDhqKmpGZP3Kil8TyorKxvyc1EUw8Y+bP5I4yetWrUqWltbB39+++23o66uLrq6usbsi3Ph6O/vjxkzZsSBAwfc6pKQ88/N+efm/HPr6+uLK6+8Mi699NIxe8+SwnfKlCkxceLEYVd3Dx06NOyq7kmXX375iPPLy8tj8uTJI66prKyMysrKYeM1NTX+i59YdXW180/M+efm/HNz/rlNmDB2T98t6Z0qKiqioaEhOjo6hox3dHREU1PTiGvmz58/bP6WLVuisbFxxPt7AQBgPJSc0K2trfHYY4/Fxo0bY+/evbFixYro6uqKlpaWiPjgNoWlS5cOzm9paYk33ngjWltbY+/evbFx48bYsGFD3HvvvWP3LQAA4EOUfI/vkiVL4vDhw7F27dro7u6O2bNnR3t7e9TV1UVERHd395Bn+tbX10d7e3usWLEiHnnkkZg2bVo8/PDD8ZWvfOWMP7OysjIeeOCBEW9/4E+f88/N+efm/HNz/rmNx/mX/BxfAAC4EI3d3cIAAPARJnwBAEhB+AIAkILwBQAghY9M+K5bty7q6+ujqqoqGhoaYtu2baedv3Xr1mhoaIiqqqqYOXNmPProo+dop4yHUs7/ueeei+uvvz4+/vGPR3V1dcyfPz9+8YtfnMPdMtZK/fN/0quvvhrl5eXx+c9/fnw3yLgq9fwHBgZi9erVUVdXF5WVlfHJT34yNm7ceI52y1gr9fw3bdoU11xzTVx88cUxderUuPPOO+Pw4cPnaLeMlZdffjluvvnmmDZtWpSVlcULL7zwoWvGpP2Kj4B/+Zd/KSZNmlT87Gc/K/bs2VPcc889xSWXXFK88cYbI87ft29fcfHFFxf33HNPsWfPnuJnP/tZMWnSpOKZZ545xztnLJR6/vfcc0/xve99r/jP//zP4rXXXitWrVpVTJo0qfjv//7vc7xzxkKp53/S22+/XcycObNobm4urrnmmnOzWcbcaM7/y1/+cjFv3ryio6Oj2L9/f/Ef//EfxauvvnoOd81YKfX8t23bVkyYMKH44Q9/WOzbt6/Ytm1b8dnPfrZYvHjxOd45Z6u9vb1YvXp18eyzzxYRUTz//POnnT9W7feRCN+5c+cWLS0tQ8Y+/elPFytXrhxx/j/8wz8Un/70p4eMff3rXy++8IUvjNseGT+lnv9IPvOZzxRr1qwZ661xDoz2/JcsWVL84z/+Y/HAAw8I3wtYqef/r//6r0VNTU1x+PDhc7E9xlmp5/9P//RPxcyZM4eMPfzww8X06dPHbY+MvzMJ37Fqv/N+q8PRo0dj165d0dzcPGS8ubk5tm/fPuKaHTt2DJt/ww03xM6dO+P9998ft70y9kZz/n/sxIkTceTIkbj00kvHY4uMo9Ge/+OPPx6vv/56PPDAA+O9RcbRaM7/xRdfjMbGxvj+978fV1xxRVx99dVx7733xh/+8IdzsWXG0GjOv6mpKQ4ePBjt7e1RFEW8+eab8cwzz8RNN910LrbMeTRW7Vfyv7ltrPX29sbx48ejtrZ2yHhtbW309PSMuKanp2fE+ceOHYve3t6YOnXquO2XsTWa8/9jP/jBD+Ldd9+NW265ZTy2yDgazfn/9re/jZUrV8a2bduivPy8/y2MszCa89+3b1+88sorUVVVFc8//3z09vbGN77xjXjrrbfc53uBGc35NzU1xaZNm2LJkiXxv//7v3Hs2LH48pe/HD/60Y/OxZY5j8aq/c77Fd+TysrKhvxcFMWwsQ+bP9I4F4ZSz/+kp556Kr773e/G5s2b47LLLhuv7THOzvT8jx8/HrfeemusWbMmrr766nO1PcZZKX/+T5w4EWVlZbFp06aYO3du3HjjjfHQQw/FE0884arvBaqU89+zZ08sW7Ys7r///ti1a1e89NJLsX///mhpaTkXW+U8G4v2O++XS6ZMmRITJ04c9v/uDh06NKzsT7r88stHnF9eXh6TJ08et70y9kZz/idt3rw57rrrrnj66afjuuuuG89tMk5KPf8jR47Ezp07o7OzM771rW9FxAchVBRFlJeXx5YtW+Laa689J3vn7I3mz//UqVPjiiuuiJqamsGxWbNmRVEUcfDgwbjqqqvGdc+MndGcf1tbWyxYsCDuu+++iIj43Oc+F5dcckksXLgwHnzwQf/E90/YWLXfeb/iW1FREQ0NDdHR0TFkvKOjI5qamkZcM3/+/GHzt2zZEo2NjTFp0qRx2ytjbzTnH/HBld477rgjnnzySfd2XcBKPf/q6ur49a9/Hbt37x58tbS0xKc+9anYvXt3zJs371xtnTEwmj//CxYsiN///vfxzjvvDI699tprMWHChJg+ffq47pexNZrzf++992LChKHpMnHixIj4f1f/+NM0Zu1X0q/CjZOTjzPZsGFDsWfPnmL58uXFJZdcUvzP//xPURRFsXLlyuK2224bnH/ykRYrVqwo9uzZU2zYsMHjzC5gpZ7/k08+WZSXlxePPPJI0d3dPfh6++23z9dX4CyUev5/zFMdLmylnv+RI0eK6dOnF3/zN39T/OY3vym2bt1aXHXVVcXdd999vr4CZ6HU83/88ceL8vLyYt26dcXrr79evPLKK0VjY2Mxd+7c8/UVGKUjR44UnZ2dRWdnZxERxUMPPVR0dnYOPspuvNrvIxG+RVEUjzzySFFXV1dUVFQUc+bMKbZu3Tr4126//fbii1/84pD5//7v/1785V/+ZVFRUVF84hOfKNavX3+Od8xYKuX8v/jFLxYRMex1++23n/uNMyZK/fP//xO+F75Sz3/v3r3FddddV1x00UXF9OnTi9bW1uK99947x7tmrJR6/g8//HDxmc98prjooouKqVOnFl/72teKgwcPnuNdc7b+7d/+7bT/Wz5e7VdWFP7ZAAAAf/rO+z2+AABwLghfAABSEL4AAKQgfAEASEH4AgCQgvAFACAF4QsAQArCFwCAFIQvAAApCF8AAFIQvgAApCB8AQBI4f8AaCkHRuWfkuQAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import networkx as nx\n",
    "import matplotlib.pyplot as plt\n",
    "names = dict(enumerate(map(lambda x: x.replace(\"_\", \"\\n\"), cat_codes.cat.categories)))\n",
    "G = nx.from_numpy_array(adjacency, create_using=nx.DiGraph)\n",
    "nodes_to_remove = [0, 1]\n",
    "G.remove_nodes_from(nodes_to_remove)\n",
    "\n",
    "# Rename nodes in the graph\n",
    "new_names = {node: names[node] for node in G.nodes}\n",
    "G = nx.relabel_nodes(G, new_names)\n",
    "\n",
    "# make the notes bigger\n",
    "# pos = nx.circular_layout(G)  # Increase the scale value to increase the space between nodes\n",
    "nx.draw(G, with_labels=True, arrowsize=20, pos=pos)\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 167,
   "metadata": {},
   "outputs": [],
   "source": [
    "g = nx.nx_agraph.to_agraph(G)\n",
    "for n in g.nodes():\n",
    "    n.attr['fontsize']='18pt'\n",
    "g.edge_attr.update(penwidth=3)\n",
    "g.layout(prog='dot')\n",
    "g.draw('graph.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'Breakfast\\nend': array([5.00000000e+00, 1.40182023e-07]),\n",
       " 'Breakfast\\nstart': array([4.69846309, 1.71010074]),\n",
       " 'Grooming\\nend': array([3.83022221, 3.21393797]),\n",
       " 'Grooming\\nstart': array([2.49999989, 4.33012731]),\n",
       " 'Leaving\\nend': array([0.86824118, 4.92403872]),\n",
       " 'Leaving\\nstart': array([-0.86824088,  4.92403872]),\n",
       " 'Lunch\\nend': array([-2.50000019,  4.33012702]),\n",
       " 'Lunch\\nstart': array([-3.83022206,  3.21393827]),\n",
       " 'Showering\\nend': array([-4.69846294,  1.71010118]),\n",
       " 'Showering\\nstart': array([-4.99999985e+00, -2.96931853e-07]),\n",
       " 'Sleeping\\nend': array([-4.69846294, -1.7101006 ]),\n",
       " 'Sleeping\\nstart': array([-3.83022236, -3.21393769]),\n",
       " 'Snack\\nend': array([-2.49999944, -4.33012703]),\n",
       " 'Snack\\nstart': array([-0.86824058, -4.92403873]),\n",
       " 'Spare\\nTime/TV\\nend': array([ 0.86824088, -4.92403844]),\n",
       " 'Spare\\nTime/TV\\nstart': array([ 2.49999959, -4.33012703]),\n",
       " 'Toileting\\nend': array([ 3.83022161, -3.21393858]),\n",
       " 'Toileting\\nstart': array([ 4.69846279, -1.71010165])}"
      ]
     },
     "execution_count": 66,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# mulitply each value in the dict pos by two, do not use nx rescale layout\n",
    "pos = nx.circular_layout(G)  # Increase the scale value to increase the space between nodes\n",
    "pos = {k: v*5 for k, v in pos.items()}\n",
    "\n",
    "pos"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "unconnected_graphs = [G]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "ename": "AttributeError",
     "evalue": "'str' object has no attribute 'attr'",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mAttributeError\u001b[0m                            Traceback (most recent call last)",
      "\u001b[0;32m/var/folders/vb/598bd39x0lj3t80ztvlt81z40000gn/T/ipykernel_17988/217571617.py\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m     59\u001b[0m                     \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     60\u001b[0m                         \u001b[0mname\u001b[0m \u001b[0;34m+=\u001b[0m \u001b[0;34m\" \"\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0mword\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 61\u001b[0;31m             \u001b[0mnode\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mattr\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m'label'\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mname\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     62\u001b[0m         \u001b[0mg\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mwrite\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34mf'graph{ind:d}.dot'\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     63\u001b[0m         \u001b[0mg\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdraw\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34mf'graph{ind:d}.png'\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mformat\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m'png'\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mprog\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m'fdp'\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0margs\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m'-Goverlap=false -Gsplines=true -Gnodesep=3 -Gstart=5'\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mAttributeError\u001b[0m: 'str' object has no attribute 'attr'"
     ]
    }
   ],
   "source": [
    "import pygraphviz as pgv\n",
    "\n",
    "# id_to_bank = dict(zip(metadata.index, metadata['Bank']))\n",
    "ind = 0\n",
    "for g in unconnected_graphs:\n",
    "    if len(g.nodes()) > 1:\n",
    "        # g = nx.relabel_nodes(g, id_to_bank)\n",
    "        # # color based on continent\n",
    "        # continent_to_color = {\n",
    "        #     'Europe': 'lightblue',\n",
    "        #     'Asia': 'pink',\n",
    "        #     'America': 'lightgreen',\n",
    "        #     'Australia': 'yellow',\n",
    "        # }\n",
    "        # color_map = []\n",
    "        # for node in g:\n",
    "        #     if node in metadata['Bank'].values:\n",
    "        #         color_map.append(continent_to_color[metadata[metadata['Bank'] == node]['Continent'].values[0]])\n",
    "        #     else:\n",
    "        #         color_map.append('black')\n",
    "        # # assign size based on mcap\n",
    "        # size_map = []\n",
    "        # for node in g:\n",
    "        #     if node in metadata['Bank'].values:\n",
    "        #         size_map.append(metadata[metadata['Bank'] == node]['Mcap'].values[0])\n",
    "        #     else:\n",
    "        #         size_map.append(100)\n",
    "        \n",
    "        # # # convert to graphviz\n",
    "\n",
    "        # g = nx.nx_agraph.to_agraph(g)\n",
    "        # # add color and size\n",
    "        # for i, node in enumerate(g.nodes()):\n",
    "        #     node.attr['color'] = color_map[i]\n",
    "        #     node.attr['style'] = 'filled'\n",
    "        #     node.attr['shape'] = 'circle'\n",
    "        #     node.attr['width'] = size_map[i]/ 100 * 1.2\n",
    "        #     node.attr['height'] = size_map[i] / 100 * 1.2\n",
    "        #     node.attr[\"margin\"] = 0.1\n",
    "        # # set fixed size\n",
    "        # g.graph_attr['fixedsize'] = \"true\"\n",
    "        # g.graph_attr['fontsize'] = \"20pt\"\n",
    "        # g.graph_attr['rankdir'] = \"LR\"\n",
    "        # g.graph_attr[\"size\"] = '90,30!'\n",
    "        # print(g.graph_attr[\"rankdir\"])\n",
    "        \n",
    "        # set node labels with newline after 10 characters\n",
    "        for i, node in enumerate(g.nodes()):\n",
    "            name = str(node)\n",
    "            counter = 10\n",
    "            if len(name) > counter:\n",
    "                # split by words\n",
    "                words = name.split(' ')\n",
    "                name = ''\n",
    "                for word in words:\n",
    "                    if len(name) + len(word) > counter:\n",
    "                        name += '\\n' + word\n",
    "                        counter += 10\n",
    "                    else:\n",
    "                        name += \" \" + word\n",
    "            node.attr['label'] = name\n",
    "        g.write(f'graph{ind:d}.dot')\n",
    "        g.draw(f'graph{ind:d}.png', format='png', prog='fdp', args='-Goverlap=false -Gsplines=true -Gnodesep=3 -Gstart=5')\n",
    "        # add legend\n",
    "        ind += 1\n",
    "        # load image\n",
    "        img = plt.imread(f'graph{ind-1:d}.png')\n",
    "        plt.figure(figsize=(30,10),dpi=500)\n",
    "        plt.imshow(img,interpolation=\"none\")\n",
    "        plt.axis('off')\n",
    "        import matplotlib.patches as mpatches\n",
    "        handles = [mpatches.Patch(color=color, label=continent) for continent, color in continent_to_color.items()]\n",
    "        plt.legend(handles=handles)\n",
    "        plt.savefig(f'graph{ind-1:d}_legend.png', bbox_inches='tight',dpi=500)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "venv",
   "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": 2
}
