{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "import collections\n",
    "import os\n",
    "import time\n",
    "\n",
    "import torch as th\n",
    "from torch import nn\n",
    "from torch.utils.data import DataLoader, Dataset\n",
    "import geoopt as gt\n",
    "\n",
    "import numpy as np\n",
    "\n",
    "import dill\n",
    "import yaml\n",
    "from tqdm import tqdm\n",
    "\n",
    "from probe.euclid import *\n",
    "from probe.hyper import *\n",
    "from util.data import custom_pad\n",
    "from util.loss import *\n",
    "from util.evalu import *\n",
    "from util.train import *"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "device = th.device('cuda:0' if th.cuda.is_available() else 'cpu')\n",
    "\n",
    "model_name = 'bert-base-cased'\n",
    "layer_index = 7\n",
    "data_dir = './data/dataset/'\n",
    "dev_distance_dataset_path = os.path.join(data_dir, \n",
    "                                         'distance', \n",
    "                                         model_name, \n",
    "                                         'dev-layer-' + str(layer_index) + '.pt')\n",
    "dev_dataset = th.load(dev_distance_dataset_path, pickle_module=dill)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Visualization"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "%matplotlib inline\n",
    "\n",
    "import random\n",
    "\n",
    "import numpy as np\n",
    "from sklearn.decomposition import PCA\n",
    "from sklearn.metrics import mean_absolute_error\n",
    "\n",
    "import matplotlib as mpl\n",
    "import matplotlib.pyplot as plt\n",
    "from matplotlib.offsetbox import AnchoredText\n",
    "from matplotlib.path import Path\n",
    "import matplotlib.patches as patches\n",
    "\n",
    "from util.viz import *\n",
    "\n",
    "plt.style.use('default')\n",
    "plt.rcParams[\"font.family\"] = \"DejaVu Serif\"\n",
    "mpl.rcParams['figure.dpi'] = 100\n",
    "\n",
    "stop_words = ',.:;?()``\\\"\\'\\''"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Constructing EuclideanProbe\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<All keys matched successfully>"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "config_file = os.path.join(\"./\", \"config\", \"example-euclidean.yaml\")\n",
    "config_yaml = yaml.load(open(config_file), Loader=yaml.FullLoader)\n",
    "probe_config = config_yaml['probe']\n",
    "PROBE_OUT = probe_config[\"dim_out\"]\n",
    "probe = EuclideanProbe(\n",
    "            device=device,\n",
    "            dim_in=probe_config[\"dim_in\"],\n",
    "            dim_out=probe_config[\"dim_out\"],\n",
    "        )\n",
    "probe.to(device)\n",
    "probe.load_state_dict(th.load('./checkpoint/syntax-euclidean-probe.pt', \n",
    "    map_location=device))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Instance: 930\n",
      "`` It was a pretty wild day .\n",
      "Sentence length: 8\n",
      "BERT_base_7 | Euclidean Dim: 768\n",
      "UUAS: 0.6000 | Root Acc: True, Depth: 0.5670\n"
     ]
    }
   ],
   "source": [
    "batch_size = len(dev_dataset)\n",
    "rand_inst_i = 930\n",
    "viz, sentence, uuas, \\\n",
    "    root_acc, root_idx, root_depth, \\\n",
    "    gold_edges, pred_edges = \\\n",
    "    vizInstance(dev_dataset, rand_inst_i, probe)\n",
    "length = len(sentence)\n",
    "print(f\"Instance: {rand_inst_i}\")\n",
    "print(' '.join(sentence))\n",
    "print(f\"Sentence length: {length}\")\n",
    "print(f\"BERT_base_{layer_index} | Euclidean Dim: {viz.shape[1]}\")\n",
    "print(f\"UUAS: {uuas:.4f} | Root Acc: {root_acc}, Depth: {root_depth:.4f}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "viz_pca = PCA(n_components=2).fit_transform(viz)\n",
    "fig, ax = plotEuclidean(viz_pca, \n",
    "                        root_idx,\n",
    "                        sentence,\n",
    "                        gold_edges, \n",
    "                        pred_edges,\n",
    "                        stop_words)\n",
    "at = AnchoredText(f\"UUAS: {uuas:.2f}\\n\" + \n",
    "                  f\"Root: {root_acc}\\n\" +\n",
    "                  f\"Root Depth: {root_depth:.2f}\",\n",
    "                  frameon=True,\n",
    "                  loc='lower right',\n",
    "                  prop=dict(fontsize=\"14\"),\n",
    "                  )\n",
    "ax.add_artist(at)\n",
    "fig.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "conda",
   "language": "python",
   "name": "conda"
  },
  "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.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
