{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "myGPT_specific(\n",
       "  (embedding): Embedding(\n",
       "    (tgt_emb): Embedding(201, 400)\n",
       "    (pos_emb): Embedding(20, 400)\n",
       "  )\n",
       "  (decoder): Decoder(\n",
       "    (layers): ModuleList(\n",
       "      (0-1): 2 x DecoderLayer(\n",
       "        (dec_self_attn): MultiHeadAttention(\n",
       "          (W_Q): Linear(in_features=400, out_features=200, bias=False)\n",
       "          (W_K): Linear(in_features=400, out_features=200, bias=False)\n",
       "          (W_V): Linear(in_features=400, out_features=200, bias=False)\n",
       "          (fc): Linear(in_features=200, out_features=400, bias=False)\n",
       "          (layernorm): LayerNorm((400,), eps=1e-05, elementwise_affine=True)\n",
       "        )\n",
       "        (pos_ffn): PoswiseFeedForwardNet(\n",
       "          (fc): Sequential(\n",
       "            (0): Linear(in_features=400, out_features=1200, bias=False)\n",
       "            (1): ReLU()\n",
       "            (2): Linear(in_features=1200, out_features=400, bias=False)\n",
       "          )\n",
       "          (layernorm): LayerNorm((400,), eps=1e-05, elementwise_affine=True)\n",
       "        )\n",
       "      )\n",
       "    )\n",
       "  )\n",
       "  (projection): Linear(in_features=400, out_features=201, bias=True)\n",
       ")"
      ]
     },
     "execution_count": 1,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import torch\n",
    "import sys\n",
    "sys.path.append('..')\n",
    "sys.path.append('../..')\n",
    "from utils import *\n",
    "from model import *\n",
    "from data import *\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "\n",
    "\n",
    "working_dir = f'./data/LLM/LLM_new/refine_adam_epoch_207_data_90w_warmup_normal_init_34_wrong_43_unseen_diff_ini/GPT_normal_init_composition_task_34_unseen_43_unseen_diff_ini_0.5_test_eps_1e-08_wd_0.01_beta2_0.999/composition-N_900000-2L1H_seed1'\n",
    "state_dict=torch.load(f'{working_dir}/model/model_80.pt')\n",
    "device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "args = load_args(f'{working_dir}/config.json')\n",
    "\n",
    "# model = myGPT(args, device)\n",
    "model = myGPT_specific(args, device)\n",
    "model.load_state_dict(state_dict)\n",
    "model.to(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "# for i in torch.linspace(0.0,0.6,100):  \n",
    "tensor_all_1=[]\n",
    "for i in range(30,41):  \n",
    "    # for j in [1,2,4]:\n",
    "    seq = [35, 66,i,3,3,38, 42, 36, 62, 33]\n",
    "    dec_logits, _ = model(torch.tensor([seq[:9]]).to(device))\n",
    "    # V=model.decoder.layers[1].dec_self_attn.V\n",
    "    attn=model.decoder.layers[1].dec_self_attn.softmax_attn\n",
    "    V=model.decoder.layers[1].dec_self_attn.V\n",
    "\n",
    "\n",
    "    tensor=model.decoder.layers[1].dec_self_attn.attention_out[0, -1, :]\n",
    "\n",
    "    tensor_all_1.append(tensor.detach().cpu().numpy())\n",
    " \n",
    "tensor_all_2=[]\n",
    "for i in range(30,41):  \n",
    "  \n",
    "    seq = [35, 66,i,2,2,38, 42, 36, 62, 33]\n",
    "    dec_logits, _ = model(torch.tensor([seq[:9]]).to(device))\n",
    "    # V=model.decoder.layers[1].dec_self_attn.V\n",
    "    attn=model.decoder.layers[1].dec_self_attn.softmax_attn\n",
    "    V=model.decoder.layers[1].dec_self_attn.V\n",
    "\n",
    "    tensor=model.decoder.layers[1].dec_self_attn.attention_out[0, -1, :]\n",
    "\n",
    "    tensor_all_2.append(tensor.detach().cpu().numpy())\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "tensor_all_1=np.array(tensor_all_1)\n",
    "tensor_all_2=np.array(tensor_all_2)\n",
    "\n",
    "from sklearn.metrics.pairwise import cosine_similarity\n",
    "\n",
    "cos_sim = cosine_similarity(tensor_all_1, tensor_all_2)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 512x384 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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MSr/gxgucKZzqDLrhri7DLtY/+ctVe0tE27jrCdHV6cfRoQAwENk+gdraP/ndb6+5ySi0Lwsfbh2hiRpRMw4nQwOcW9BdgjLzdLypW+7u4zLntVqdXcJkghCAOAxir28lV4nRPl1PScIXexkcIhHBCGYi+edKwAAAHASghAAADAtghAAAKgVvvnmG3l7e6tVq1aXvIaouLhYrVq1ko+Pj113llWEIAQAAGqFjz/+WIZh6N5775WXV+URxdvbW/fdd5+sVqtWrFhR5W0ShAAAQK2wdetWWSwW9evXz672Je2++eabKm+TIAQAAGqF48ePS5Latm1rV/vWrVtLqt5LWglCAACgVsjJyZGkSz5xukRJuzNnzlR5mwQhAABQK4SFhUmSDh06ZFf7knYNGzas8jYJQgAAoFbo1q2bJOnDDz+0q31Ju+uuu67K2yQIAQCAWiE6OlqGYej999/XypUrK22bkJCg999/XxaLRcOGDavyNglCAACYQGpqqt577z2NGTNGXbt2VbNmzVSnTh0FBgaqVatWiomJ0bp16+zu79tvv9XYsWPVtm1b1a1bV/Xr11f79u0VExOj2bNnV6nGmJgYXXfddSouLtb//d//6Z577tGXX36pU6dOqaCgQKdOndKXX36pe+65R9HR0SouLlbnzp01cuTIKm1P4l1jAACYwhdffKGHH3643GUpKSlKSUnRihUrFBUVpWXLlikwMLDctufPn9eDDz6oRYsWlVmWlZWln3/+WStWrFBcXJzDNVosFq1atUp//etfdeTIES1ZskRLliwpt61hGGrdurVWr15t98XV5WFECAAAE/D391ffvn01bdo0JSYmKikpSRkZGTp06JASEhLUu3dvSdKaNWs0duzYcvsoLi7WnXfeqUWLFslisejee+/V119/rdTUVKWlpWnbtm168cUXbbe1V0WzZs20a9cuxcXFyc/PT4ZhlPny9/fXI488ol27dqlZs2ZV3pbEiBAAAKYQHR2t6OjoMvNDQ0PVpk0bDRkyRIMGDdK6deu0bNkyTZ06VREREaXavvnmm1q3bp0sFouWLl2qmJiYUssbNWqkG264QS+99FK1aq1fv75mzZql119/XVu3blVycrKysrJUr149tWnTRr169VJQUFC1tlGCIAQAAGSxWDRmzBjbdUK7du0qFYTOnDljCzj33XdfmRDkCsHB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tk0HDhxQjx49JEl33nmn/vOf/+jdd9/V1VdfrZiYGBUXF2v16tV64YUXZLFYygQkRxCEAAAuY7V4KcOvnor9/d1dSpWk1wlRekB9d5dhGkOGDNHUqVP12WefaezYsZKkkSNHKj4+Xnv27FFcXJzi4uJs7Q3DUGBgoCZNmlTlbXLXGAAAqBW6deumVatW6f7777fN8/b21vr169W/f38ZhlHqq1WrVvr888/VoUOHKm+TESEAAFBrREVFlZnXqFEjff7550pJSdHevXt1/vx5tWrVStdff728vKo3pkMQAgAAHqFly5Zq2bKlU/vk1BgAADAtghAAADAtghAAADAtghAAADAtghAAADAtghAAADAtghAAADAtghAAADAtghAAADAtghAAADAtghAAADAtghAAADAtghAAADAtghAAADAtghAAADAtghAAADAtghAAADAtghAAADAtghAAADAtghAAADAtghAAADAtghAAADAtghAAADAtghAAADAtghAAADAtghAAADAtghAAADAtghAAADAtghAAADAtghAAADAtghAAADAtghAAADAtghAAADAtghAAADAtghAAADAtghAAADAtghAAADAtH3cXAABAbdXwfJa7S7CLp9RZG9kXhAqL5Lsn2cWlOM+5W692dwkOyW5X390lOCxsf6G7S3BYzpWel/vTugS4uwSH1f+12N0lOOyXh9q7uwSHNJ5z1N0lOOz4i1e5uwS7Ffv42qbnbHvXjZU4ppm7C/BQnBoDAACm5Xl/IgMA4EKZfkGKvuk5+f+e7e5SHJJ5ZIFUlOvuMjwOQQgAgIsUe3krPaC+Anwt7i7FIVZO8lQJRw0AAJgWQQgAAJgWQQgAAJgWQQgAAJgWQQgAAJgWQQgAAJgWQQgAAJgWQQgAAJgWQQgAAJgWQQgAAJgWQQgAABNITU3Ve++9pzFjxqhr165q1qyZ6tSpo8DAQLVq1UoxMTFat27dJfv5/fff9fe//13dunVTSEiIfH191bBhQ/Xo0UNTpkxRenp6DeyN8/CuMQAATOCLL77Qww8/XO6ylJQUpaSkaMWKFYqKitKyZcsUGBhYpl1iYqKGDRums2fPlpp/+vRpbdu2Tdu2bdOMGTOUkJCgG2+80SX74WyMCAEAYAL+/v7q27evpk2bpsTERCUlJSkjI0OHDh1SQkKCevfuLUlas2aN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",
      "text/plain": [
       "<Figure size 960x640 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.patches as patches\n",
    "\n",
    "\n",
    "format_settings(wspace=0.4, hspace=0.6, bottom=0.16, fs=24, lw=6, ms=12.5, axlw=2.5, major_tick_len=6)\n",
    "plt.figure(figsize=(12,8))\n",
    "ax = plt.gca()  \n",
    "\n",
    "\n",
    "plt.imshow(cos_sim, vmin=0.2, vmax=1)\n",
    "# plt.imshow(cos_sim)\n",
    "plt.xticks(np.arange(0,11,2), np.arange(30,41,2))\n",
    "plt.yticks(np.arange(0,11,2), np.arange(30,41,2))\n",
    "ax.xaxis.tick_top()  \n",
    "ax.xaxis.set_label_position('top')  \n",
    "ax.yaxis.tick_right()  \n",
    "ax.yaxis.set_label_position('right') \n",
    "\n",
    "plt.xlabel('anchor: 13')\n",
    "plt.ylabel('anchor: 12')\n",
    "\n",
    "for [row, col] in [[0, 3], [1,4], [2,5], [3, 6], [4, 7], [5,8], [6,9], [7,10]]:\n",
    "    rect = patches.Rectangle((col-0.5, row-0.5), 1, 1, linewidth=2, edgecolor='r', facecolor='none')\n",
    "    plt.gca().add_patch(rect)\n",
    "\n",
    "plt.savefig('./LLM/plot_for_neurips/pic/cos_sim_12_13_linear.png', dpi=300)\n",
    "\n",
    "plt.colorbar()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 512x384 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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CSwAAABQ1pxOYA8ePOiBMAAAACqhcrIObEJCgt555x1t3bpV6enpqlu3riIjI/XYY4/pxhtvdMs5UlJSNHPmTP3nP/9RcnKyMjIyVLduXTVv3lzdu3fXyJEj1bhxY4fG4lWyAAAAlVhsbKzi4uIKfPb7779r/vz5WrRokV566SWNHz++VOdYtGiRHnzwQZ0+fbrQeX7//XetW7dOTZo00b333uvQeE6vQgAAAAD3sBie2Rz12muv2ZLXvn37asuWLUpNTdW6devUpUsX5ebmasKECfrqq69cvsZPP/1Uf/vb33T69Gldd911+uSTT5ScnKz09HTt3btXc+bMUa9eveTr6+vwmG6pwJ47d06HDx9WRkaGQkND1ahRI1WrVs0dQwMAAMAD0tLSNGXKFElSjx49FB8fLx+fK7XN7t27a+3atWrfvr327t2rcePGqV+/fvL393fqHAcPHtQDDzwgq9WqqKgoffHFF6pSpYqtvWbNmmrZsqVGjBjh1LguV2Bzc3P1zjvvqH379qpVq5auv/56devWTddff71q1aql9u3b67333lNubq6rpwAAAKi4PLUGrINrwc6bN08ZGRmSpJdfftmWvOYJCgrS1KlTJV1JRJcvX+70JU6aNEnnz59XWFiY5syZUyB5LQ2XEtgTJ06oS5cuevTRR/Xrr7/KarXKMAzbZrVa9csvv+jhhx9WRESETp486ZZgAQAA4B7x8fGSpKZNm6pTp05F9omOjlZAQIAkacmSJU6Nf+rUKdtSq/fee69q1qxZimgLcnoKQW5urvr27auff/5ZhmGoTZs2GjRokK699lqFhoYqMzNTiYmJ+uKLL7Rr1y5t27ZN/fr1048//lgoswcAAIA5tm/fLkmKiIgotk9AQIA6dOigTZs22fo76ptvvtHFixclSbfddluBtsuXL5eqGut0RvnRRx9px44dslgseu2115SYmKjJkyfr7rvvVu/evTVw4EBNnjxZO3fu1Ouvvy6LxaLt27fro48+cjlIAAAAuM/Ro0dt0weaNWtmt2/Tpk0lSfv27ZNhOP6E2NatW237bdq00bZt2zRw4EBVr15d/v7+Cg0N1a233qrPP//c6fidTmAXLVoki8Wixx57TP/4xz/s9o2NjdWjjz4qwzC0cOFCp4MDAACoyMxahSAtLc22X69ePbt989qzs7OVmZnp8LUdPnzY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MgYAlAdUYAHAC1y6dEnZ2dkKCgrS8OHD9dlnnykpKUnp6enauXOnnnjiCfn6+urw4cO67bbbdOzYMY+MAQDlARVYAF6pMlZg33rrLY0fP161atUqss8nn3yiYcOGSZIefvhhvfXWW24fAwDKAxJYAF6psiWwjmrbtq127typpk2b6sCBA6aNAQCexBQCoJIyDENbtmzRM888o65du6p27dqqUqWKatasqU6dOmny5Mk6depUscfPmTPH9iCVJKWlpWnChAlq0aKFAgMDVbt2bfXp00fffvttibFYrVbNnz9fAwYMUMOGDRUYGKiwsDC1a9dOjzzyiDZs2FDiGHPnzlW3bt1Us2ZNBQcH6/rrr9e///1vXbp0qcT7sGDBAvXt21f169eXv7+/6tSpo1tuuUXvv/++cnJyij22SZMmslgsmjJliiRp4cKFuu2221S/fn35+vqaklhfe+21kqSjR4+aOgYAeJQBoFL6+uuvDUl2t/r16xs7duwo8vjZs2fb+u3atcsIDw8vcgyLxWLMnTu32DgOHz5sdOzYscRY/ijv81mzZhl33313scfddtttRm5ubpHnPnv2rNGzZ0+7523fvr1x7NixIo9v3LixIcl49tlnjWHDhhU6dsSIEba+I0aMsH2enJxc7P0orbzrCQsLM3UMAPAkKrBAJeXn56eoqCjNnDlTGzduVFJSktLS0pSYmKiZM2eqZcuWOnHihO66664Sn1rv37+/qlSponnz5un3339XamqqFi9erD/96U8yDEMPP/xwkdXcM2fOqEePHtq2bZt8fHz0wAMP6Pvvv1dKSopOnjypjRs3avLkyWrUqFGx537xxRe1ePFiPfnkk9q5c6fS09P1888/a8CAAZKkVatWadasWUUeGxMTo7Vr10qShg0bpq1bt+rUqVP69ddfFRsbK4vFoh07dqhfv366fPlysTF89NFH+vjjjzVixAj9+OOPSktL0549ezRy5Ei7983dTp48qe+++06SFBERYdoYAOBxZmfQAMqnjIwMo3nz5oYk46OPPirUnr8CGx4ebpw8ebJQn23bttn6vPvuu4XaH3zwQVv7okWLio3l8uXLhT5TvkrnJ598Uqg9NzfXaNeunSHJuPHGGwu1569AP/7440We99VXX7X1mTFjRqH2vAqsJOOJJ54oNn7DKJsK7PDhw23nWLFihWljAICnkcACKNaECRMMScaQIUMKteVPYGfOnFnsGG3btjUkGffdd1+Bz8+ePWsEBAQYkoy//e1vTseWd+6IiIhi+7z22muGJMPf379QEtyvXz/b1+RZWVlFHm+1Wo02bdoYkoy2bdsWas9LYGvWrFnsGGVl7ty5tnsSHR1t2hgAUBaYQgBUYjk5OZo7d66ioqLUqFEjBQcH2x7Mslgsmj59uiRp7969dsfp06dPsW2tWrWSJJ04caLA5xs3btTFixclqVQPOzly7kuXLun06dO2zw3D0Pfffy/pyvSHwMDAIo+3WCwaNGiQJGnnzp06c+ZMkf169uxZ7Bhl4YcfftADDzwgSWrcuLE+/PBDU8YAgLLiZ3YAAMyRkpKiPn36aPv27SX2PXv2rN32Bg0aFNsWHBwsSbpw4UKBz5OSkmz77dq1KzGG0pz7j+c/d+6cLaFt06aN3fHznsg3DEOHDx9WjRo1CvVp1qyZMyG71c6dO9WvXz9lZ2erTp06SkhIUO3atct8DAAoS1RggUpqxIgR2r59u/z8/PTYY49p9erVSk5O1qlTp5SRkaGMjAxNnDhRkuwuJSVJvr6+JZ7P+MOS0+fOnbPth4aGunAFjp/7j+fPyMhw+Nz52/Mfl1/+RLks7d+/X7feeqtOnz6tGjVqaNWqVbaqc1mOAQBljQosUAkdOHBAK1eulCTNmDFDY8aMKbLfH6um7lStWjXbfkZGRpl+BZ8/Kc3MzLTbN397aRJtdzt06JBuueUWnTx5UiEhIVqxYoXTlWx3jAEAZqACC1RCP//8s21/yJAhxfbbuXOnx2K4+uqri4ynLFSrVk01a9aUJO3atctu38TERElX5sPaW86rLB07dky33HKLfv/9dwUGBio+Pl5dunQp8zEAwCwksEAllPfwlCTl5uYW2efw4cMOvQHLVd26dbNVXefOneux8xTFYrGoW7dukqSlS5cWuB/5GYahL774QpJ03XXXFTn/taylpKTolltuUVJSkvz9/fXll1+qR48eZT4GAJiJBBaohPI/dLRkyZJC7ZcvX9bo0aOLTW7dITQ0VKNGjZIkzZ8/X19++WWxfUuag+uK0aNHS5JSU1P1zDPPFNknLi7OVqG9//773R6Ds06fPq3bbrtNe/bska+vr+bPn6877rijzMcAALORwAKV0A033GBLYmNjYxUXF6ekpCSlpqZq5cqV6t69u1avXl3iE/ql9cILL6h58+YyDEODBw/WQw89pE2bNiktLU2pqanavHmznn/+ebVo0cLt546KirItwfXKK69o5MiR2rZtm9LT05WYmKjHH39cY8eOlSR16NCh1Ansvffea1ue7ODBg04ff/78ed1xxx365ZdfJF2Zu9y7d29lZmYWu/3xwTl3jAEA5YJ5S9ACMNP69euNoKCgAm+0yr+NHz/emDx5siHJaNy4caHj87/IwJ68N1B17969yPZDhw7Z3phlb/ujvM9nz55d7Lm//fZbu2+/Onv2rNGzZ0+7523fvr1x7NixIsfPe5HB5MmT7d6D/PehuFhKkv9aHN3+eB53jAEA5QEVWKCSuummm7RlyxbFxMSobt26qlKliurXr69+/fpp6dKltpcYeFqjRo30008/ac6cOerTp4/q1aunKlWqqE6dOmrXrp0effRRbdy40SPnrlatmtasWaNPP/1Uffr0sd2H2rVrq0ePHnrvvfe0ZcsWXXXVVR45PwDANRbD4PshAAAAeA8qsAAAAPAqJLAAAADwKiSwAAAA8CoksAAAAPAqJLAAAADwKiSwAAAA8CoksAAAAPAqJLAAAADwKiSwAAAA8CoksAAAAPAqJLAAAADwKiSwAAAA8Cr/B50+da6hoMYeAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 960x640 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.patches as patches\n",
    "\n",
    "\n",
    "format_settings(wspace=0.4, hspace=0.6, bottom=0.16, fs=24, lw=6, ms=12.5, axlw=2.5, major_tick_len=6)\n",
    "plt.figure(figsize=(12,8))\n",
    "\n",
    "plt.imshow(cos_sim, vmin=0.2, vmax=1)\n",
    "\n",
    "plt.xticks(np.arange(0,11,2), np.arange(30,41,2))\n",
    "plt.yticks(np.arange(0,11,2), np.arange(30,41,2))\n",
    "\n",
    "plt.xlabel('anchor: 22')\n",
    "plt.ylabel('anchor: 33')\n",
    "\n",
    "for [row, col] in [[6, 0], [7,1], [8,2], [9, 3], [10, 4]]:\n",
    "    rect = patches.Rectangle((col-0.5, row-0.5), 1, 1, linewidth=2, edgecolor='r', facecolor='none')\n",
    "    plt.gca().add_patch(rect)\n",
    "\n",
    "cbar=plt.colorbar()\n",
    "\n",
    "cbar.set_ticks([0.2, 0.4, 0.6, 0.8, 1.0])\n",
    "plt.savefig('./LLM/plot_for_neurips/pic/cos_sim_22_33_linear.png', dpi=300)\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "pytorch_zzw",
   "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.12.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
