{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "d92ac25f-38e3-4fdd-b584-79e9cc5b8e39",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<svg  width=\"550\" height=\"55\"><rect x=\"0\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#0173b2;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"55\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#de8f05;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"110\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#029e73;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"165\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#d55e00;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"220\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#cc78bc;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"275\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#ca9161;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"330\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#fbafe4;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"385\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#949494;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"440\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#ece133;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"495\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#56b4e9;stroke-width:2;stroke:rgb(255,255,255)\"/></svg>"
      ],
      "text/plain": [
       "[(0.00392156862745098, 0.45098039215686275, 0.6980392156862745),\n",
       " (0.8705882352941177, 0.5607843137254902, 0.0196078431372549),\n",
       " (0.00784313725490196, 0.6196078431372549, 0.45098039215686275),\n",
       " (0.8352941176470589, 0.3686274509803922, 0.0),\n",
       " (0.8, 0.47058823529411764, 0.7372549019607844),\n",
       " (0.792156862745098, 0.5686274509803921, 0.3803921568627451),\n",
       " (0.984313725490196, 0.6862745098039216, 0.8941176470588236),\n",
       " (0.5803921568627451, 0.5803921568627451, 0.5803921568627451),\n",
       " (0.9254901960784314, 0.8823529411764706, 0.2),\n",
       " (0.33725490196078434, 0.7058823529411765, 0.9137254901960784)]"
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import sys\n",
    "import os\n",
    "root_dir = '/home/qingli/Desktop/Closed-Loop-Learning/nsr/'\n",
    "os.chdir(root_dir)\n",
    "from train import *\n",
    "from matplotlib import pyplot as plt\n",
    "%matplotlib inline\n",
    "import seaborn as sns\n",
    "sns.set_theme()\n",
    "sns.set_context(\"notebook\", font_scale=1.5)\n",
    "sns.color_palette('colorblind')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 79,
   "id": "5cf06237-e03e-4e83-9076-f7b98c8ea81e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "CUDA is available?: True\n",
      "using cuda?: True\n"
     ]
    }
   ],
   "source": [
    "sys.argv = ['']\n",
    "args = parse_args()\n",
    "args.dataset = 'scan'\n",
    "args.split = 'simple'\n",
    "args.perception = True\n",
    "args.resume = 'analysis/models/scan/run-20220921_221927-cwtiabcp/ckpt/model_100.p'\n",
    "domain = get_dataset(args.dataset)\n",
    "args.domain = domain\n",
    "args.train_set = domain('train', n_sample=args.train_size)\n",
    "args.val_set = domain('val')\n",
    "args.test_set = domain('test')\n",
    "model = Jointer(args)\n",
    "if args.resume:\n",
    "    st_epoch = model.load(args.resume)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "id": "f44d1ca6-311f-4076-8e0e-7195910a8b7a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(14, 50)"
      ]
     },
     "execution_count": 42,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model.syntax.model.embeddings.weight.detach().numpy().shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2fe069d0-0220-4e81-9473-10dc4b85b071",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 13/13 [04:24<00:00, 20.34s/it]\n"
     ]
    }
   ],
   "source": [
    "model.eval()\n",
    "batch_size = 32\n",
    "dataloader = torch.utils.data.DataLoader(args.test_set, batch_size=batch_size,\n",
    "                         shuffle=False, num_workers=4, collate_fn=args.domain.collate)\n",
    "perm_acc = np.ones((len(domain.vocab), len(domain.vocab)), dtype=float)\n",
    "for i in trange(len(domain.vocab)):\n",
    "    for j in range(len(domain.vocab)):\n",
    "        if i == j: continue\n",
    "        dep_pred_all = []\n",
    "        dep_pred_all_perm = []\n",
    "        for sample in dataloader:\n",
    "            sent = sample['sentence']\n",
    "            sent = [x for x in sent if i in x]\n",
    "            sent_perm = [list(map(lambda y: j if y == i else y, x)) for x in sent]\n",
    "\n",
    "            parses = model.syntax(sent)\n",
    "            dep_pred_all.extend([pt.head for pt in parses])\n",
    "\n",
    "            parses = model.syntax(sent_perm)\n",
    "            dep_pred_all_perm.extend([pt.head for pt in parses])\n",
    "            # print(sent, dep_pred_all)\n",
    "            # print(sent_perm, dep_pred_all_perm)\n",
    "            # input()\n",
    "        acc = np.mean([x == y for x, y in zip(dep_pred_all, dep_pred_all_perm)])\n",
    "        perm_acc[i,j] = acc"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 124,
   "id": "e374fe06-08b5-42c8-849d-cdf8f79fa831",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "columns = domain.vocab\n",
    "sns.heatmap((perm_acc + perm_acc.T)/2, \n",
    "        xticklabels=columns,\n",
    "        yticklabels=columns,\n",
    "        cmap='coolwarm', vmin=-0.2, vmax=1.2)\n",
    "plt.xticks(\n",
    "    rotation=60, \n",
    "    horizontalalignment='center'\n",
    ")\n",
    "plt.savefig('analysis/scan_syntax.pdf', dpi=300, bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 95,
   "id": "f25ab3cf-5524-41ae-a529-d17d8414283c",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 13/13 [01:02<00:00,  4.80s/it]\n",
      "100%|██████████| 13/13 [01:00<00:00,  4.68s/it]\n",
      "100%|██████████| 13/13 [01:01<00:00,  4.71s/it]\n",
      "100%|██████████| 13/13 [01:00<00:00,  4.63s/it]\n",
      "100%|██████████| 13/13 [01:00<00:00,  4.66s/it]\n",
      "100%|██████████| 13/13 [01:23<00:00,  6.41s/it]\n",
      "100%|██████████| 13/13 [01:24<00:00,  6.47s/it]\n",
      "100%|██████████| 13/13 [01:15<00:00,  5.80s/it]\n",
      "100%|██████████| 13/13 [00:56<00:00,  4.36s/it]\n",
      "100%|██████████| 13/13 [01:16<00:00,  5.89s/it]\n",
      "100%|██████████| 13/13 [01:05<00:00,  5.02s/it]\n",
      "100%|██████████| 13/13 [01:07<00:00,  5.22s/it]\n",
      "100%|██████████| 13/13 [01:09<00:00,  5.31s/it]\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<AxesSubplot:>"
      ]
     },
     "execution_count": 95,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "model.eval()\n",
    "batch_size = 32\n",
    "dataloader = torch.utils.data.DataLoader(args.train_set, batch_size=batch_size,\n",
    "                         shuffle=False, num_workers=4, collate_fn=args.domain.collate)\n",
    "perm_acc_train = np.ones((len(domain.vocab), len(domain.vocab)), dtype=float)\n",
    "for i in range(len(domain.vocab)):\n",
    "    for j in trange(len(domain.vocab)):\n",
    "        if i == j: continue\n",
    "        dep_pred_all = []\n",
    "        dep_pred_all_perm = []\n",
    "        for sample in dataloader:\n",
    "            sent = sample['sentence']\n",
    "            sent = [x for x in sent if i in x]\n",
    "            sent_perm = [list(map(lambda y: j if y == i else y, x)) for x in sent]\n",
    "\n",
    "            parses = model.syntax(sent)\n",
    "            dep_pred_all.extend([pt.head for pt in parses])\n",
    "\n",
    "            parses = model.syntax(sent_perm)\n",
    "            dep_pred_all_perm.extend([pt.head for pt in parses])\n",
    "            # print(sent, dep_pred_all)\n",
    "            # print(sent_perm, dep_pred_all_perm)\n",
    "            # input()\n",
    "        acc = np.mean([x == y for x, y in zip(dep_pred_all, dep_pred_all_perm)])\n",
    "        perm_acc_train[i,j] = acc\n",
    "columns = domain.vocab\n",
    "sns.heatmap((perm_acc_train + perm_acc_train.T)/2, \n",
    "        xticklabels=columns,\n",
    "        yticklabels=columns)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 96,
   "id": "b949d65a-7370-4ec0-bc4b-744033837b49",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[1.   1.   1.   1.   1.   1.   1.   1.   1.   1.   1.   0.69 0.63]\n",
      " [1.   1.   1.   1.   1.   1.   1.   1.   1.   1.   1.   0.74 0.69]\n",
      " [1.   1.   1.   1.   1.   1.   1.   1.   1.   1.   1.   0.75 0.7 ]\n",
      " [1.   1.   1.   1.   1.   1.   1.   1.   1.   1.   1.   0.75 0.69]\n",
      " [1.   1.   1.   1.   1.   1.   1.   1.   1.   1.   1.   0.74 0.69]\n",
      " [0.36 0.36 0.36 0.36 0.36 1.   1.   1.   1.   1.   1.   0.87 0.86]\n",
      " [0.36 0.36 0.36 0.36 0.36 1.   1.   1.   1.   1.   1.   0.87 0.86]\n",
      " [0.4  0.4  0.4  0.4  0.4  1.   1.   1.   1.   1.   1.   0.75 0.7 ]\n",
      " [0.47 0.47 0.47 0.47 0.47 1.   1.   1.   1.   1.   1.   0.72 0.69]\n",
      " [0.39 0.39 0.39 0.39 0.39 1.   1.   1.   1.   1.   1.   0.48 0.46]\n",
      " [0.42 0.42 0.42 0.42 0.42 1.   1.   1.   1.   1.   1.   0.52 0.5 ]\n",
      " [0.97 0.94 0.92 0.96 0.81 0.92 0.04 0.61 0.09 0.47 0.36 1.   1.  ]\n",
      " [0.97 0.94 0.92 0.96 0.81 0.92 0.04 0.61 0.09 0.47 0.36 1.   1.  ]]\n"
     ]
    }
   ],
   "source": [
    "np.set_printoptions(precision=2, suppress=True, linewidth=100)\n",
    "print(perm_acc_train)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "ans",
   "language": "python",
   "name": "ans"
  },
  "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.15"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
