{
 "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",
    "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.8_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": 77,
   "metadata": {},
   "outputs": [],
   "source": [
    "# for i in torch.linspace(0.0,0.6,100):  \n",
    "tensor_all_1=[]\n",
    "for i in range(50,61):  \n",
    "    # for j in [1,2,4]:\n",
    "    seq = [35, 66,i,4,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",
    "    # V=\n",
    "\n",
    "    # attn[0,0,-1,3]=torch.tensor(0, device=device)\n",
    "    # attn[0,0,-1,4]=torch.tensor(0, device=device)\n",
    "    # print((1-attn[0,0,-1,4].item())*70+attn[0,0,-1,4].item()*70-7)\n",
    "    # qkv=torch.matmul(model.decoder.layers[1].dec_self_attn.softmax_attn, V)\n",
    "\n",
    "    tensor=V[0,0,3,:]\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",
    "\n",
    "\n",
    "tensor_all_2=[]\n",
    "for i in range(50,61):  \n",
    "    # for j in [1,2,4]:\n",
    "    seq = [70, 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",
    "\n",
    "    tensor=V[0,0,3,:]\n",
    "    # tensor=model.decoder.layers[1].dec_self_attn.attention_out[0, -1, :]\n",
    "\n",
    "    tensor_all_2.append(tensor.detach().cpu().numpy())\n",
    "    \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 78,
   "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": 72,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 512x384 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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GVq4cKEk6fnnn9cbb7xRbLuyhquyqF69un3aUcCoSMHBwUpJSbnqv9GV88sT2Fzt/Pnz6tGjh2JiYuTr66svvvhCd999t6fLAkyLPUKocA0bNtSDDz6od999VydOnND06dMlSadPn1ZUVJTb6mjcuLF9uqRzZxISEkq85NqRJk2ayGq9/L/UlYePXCkmJsYecoYMGeKw3f79+ytkfEmFDt944rlYTZo0kXT5VgglufK8oIJlPC01NVX33HOP9u3bJ6vVqoULF6p///6eLgswNYIQ3Mpqter555+37z2JiYlx29idOnWyB5VVq1Y5bFfSvJLUqFFDt956qyRpyZIlTvVxNVlZWfZpR4e90tPTtXLlygoZX5Jatmyp+vXrS5I++eSTChvHkS5dukiStm7dqnPnzjlst3TpUklSaGio/b5InpSRkaHevXtr586dslgs+uCDDzR06FBPlwWYHkEILnfy5EllZ2c7nP/bb7/p4sWLkqSaNWu6qyxdd9119kMQ7733nn755ZcibWw2m1577TWnx3jmmWckSTt27LDv+XLEMIyrXtX1e02bNrVPFxfYDMPQE088Ue5HeFzNk08+KelyGJk1a5bDdoZhXPU8pbJ69NFHJUk5OTl64oknipxDJF3eNtHR0fb2BQHYU7KystS/f39t3bpVkvT222/rscce82hNAC4jCMHlFi1apEaNGmn8+PFas2aNYmNjlZKSopMnT+qLL75Q9+7dZRiGrFarHnzwQbfWNmPGDPn5+Sk9PV3dunXTokWLdPbsWSUkJGjlypXq3Lmz0tPTnT5v6b777rP/lT9p0iT17t1bq1evVlxcnC5cuKBff/1VGzdu1Msvv6yWLVvag1NpXXfdderWrZskafr06XrllVd05MgR2Ww2fffdd+rTp4+ioqKuekVVeY0fP14dO3aUdDn8DRkyRJs2bVJCQoJsNpv27NmjWbNm6cYbbyzxuWfOuOmmm+x3n/7yyy/Vp08fbdu2TcnJyfrll1/06quv2i+db9iwoV588cVyjTdlyhT7bQk2b95c5uXz8vI0ePBgbdiwQZL0wgsv6NFHHy3x9gquDo8AHONkaVSIc+fOac6cOZozZ06x8318fDRnzpxyXX7tjBtvvFGffvqp/vKXv+i3336zP3SzQNWqVbVs2TKNHj1aKSkpTt3TJSoqSqGhoZo7d66io6PteyaK40xg+eCDD9S5c2fZbDZNmTKlyINhBw0apLvuusu+56Qi+Pn5KTo6Wg888IA2btyoJUuWVNjhwOK88847Sk1N1eLFi7VmzRqtWbOmSJsmTZpo7dq1bjsZ35Fff/210KHK6dOnX3Vv4aZNmzzy4FfAjNgjBJd78skntXTpUo0ePVodOnRQeHi4/Pz8FBQUpMjISI0ZM0Y///yz/u///s8j9T344IPas2ePHnroIV133XWqUqWKGjRooIcffli7du1Sz5497VccXXmFVGn5+fnp3Xff1b59+zRmzBi1bt1a1atXl4+Pj0JCQnTzzTfr8ccf18qVK50KDxEREfrxxx81atQo1a9fX35+fqpdu7buuOMO/etf/9KSJUvccigoNDRU3377rZYvX66BAweqfv36qlKlisLCwtS6dWs9+uijWrdunRo1auTysatUqaLPPvtM0dHRGjhwoP0zFhISok6dOunNN9/UwYMHFRER4fKxAVxbLEZxB9gBE0tOTrafu7Rs2TINHDjQwxUBACoKe4SA31m9erV9un379h6sBABQ0dgjBNNJTk5WWFhYsfPOnTunDh06KC4uTrfeeqt++OEHN1cHAHAnghBMp1+/fvLz89NDDz2k9u3bq0aNGkpKStLGjRv1+uuv269y2rBhg7p37+7hagEAFanch8ZiY2MLPfW6pNfu3btL7GvdunXq16+fwsPDFRAQoEaNGmno0KHasWNHecus1Mq7jXNzc7VhwwY9++yz6ty5s2rXrm0/sbR9+/aaOHGi/UGWZpCXl6dly5bpvvvuU5MmTRQaGqpmzZpp9OjRhS717tGjh9Of5SslJiaqVq1a9mV/f6Wambjy+0KStm3bplGjRqlZs2YKCgpSjRo1FBERocGDB+uDDz5wwxp5J1dt599++01///vfdcsttygkJER+fn4KCwtTp06dNHXqVJc8QPlaUp7P45IlS9SjRw/VrVtXAQEBatq0qR5//HEdPnzYTdWbmFFOJ0+eNCSV6rVr1y6H/TzxxBMOl/Px8TFmzpxZ3lIrrfJu4xtvvPGqywUGBhoLFy70wNq5344dO4xnn33WaN++vVGvXj2jSpUqRrVq1Yzrr7/eJZ/l33vooYcKLTt8+PCKWzkv56rvi8zMTGP48OFX7cOsXLGd//3vfxs1atQocdmwsDBjy5Ytbl4771Oez2NOTo4xcOBAh8sEBAQYixcvdvMamYtLg1B0dLSRlpbm8JWXl1dsH2+99Za9j969exs7d+40EhMTjc2bNxsdO3a0z1u2bFl5y62UyruNGzdubFgsFqNHjx7Ghx9+aBw4cMCw2WzGiRMnjPfee8+oWbOmIcmwWCzGmjVrPLCG3sEVn+XfW7t2rSGpUMgiCJVvG+fm5hq9evWyf2YfeeQRY/PmzUZ8fLyRkJBg/PDDD8bLL79s/OEPf3Dz2nmP8m7nU6dOGUFBQYYko1q1asbrr79u7N+/30hMTDT27NljPPXUU4avr68hyQgNDTUSEhI8sJbeobyfx3HjxhX6bti/f7+RkJBgrFmzxoiIiDAkGX5+fsb27dvdvGbm4dIgtGnTpjIvn5iYaAQHBxuSjD//+c9F/qfMyMgwWrRoYUgymjRpYmRlZZW35EqnvNv42WefNWJiYhzOP3z4sP1LLzIyshyVVm7l3c6/l56ebjRu3NiQZPz73/8mCBmu2cZvvvmm/Ufn888/d22B14jybucXX3zRvvzSpUuLbfPGG2/Y28yePbucFVde5fk8Hjp0yLBarQ6/F86dO2fUqlXLkGT86U9/clHF+D2PXz7/ySefKC0tTdLlxx/8/kZwVatW1dSpUyVdPu5d0l16UbyZM2eqRYsWDudHRERoxIgRki4/0fv06dPuKu2a9tJLL+nUqVMaNGiQ/RlnKJ+UlBT7nbRHjhypwYMHe7aga9TevXslSYGBgQ7vo/Xwww/bp9358GRvUt7P47x585Sfny9fX99i7zZep04dPffcc5Kk//73v/Z/F7iWx4NQwT1bmjZtqltuuaXYNv369ZO/v78k558MjpJd+XTuM2fOeLCSa8OuXbs0Z84c1ahRQ2+//bany7lmfPrpp8rIyJAkPfXUUx6u5toVEBAgSbJYLA7b+Pj42Kfr1KlT4TV5o/J+Hgt+/7p06aJ69eoV26bguXkSv38VpUKCUElPHv+9PXv2SJI6derksI2/v7/atWtXqL3ZlWUbl0ZCQoJ92pnHSlyrnNnOubm5euyxx5Sfn69p06Y5/ILDZWXZxgV7hMPDwxUZGWl/Pz8/nweVXkVZtnPB9+3Fixcd7oX/4osv7NM9e/YsX3GVVHk+jzabzX61bkm/f40bN7Z/h/D7VzFcGoTGjh2r4OBg+fv7y9/fX5GRkRo/fryOHTtWbPszZ87YD4tdf/31JfbdtGlTSdLRo0dlmPjWR2XdxqW1bNkySZefH8Xzmcq3nWfOnKl9+/bp1ltvtT8lHUU5s4137dol6fLDag3D0Pz589WuXTsFBATIz89PDRs21KhRo3T06FF3rYbXc2Y7jxkzxr6XZ9iwYZo7d65Onz6tzMxMHT9+XFOnTtWECRMkSc8884w6duzolnXxNuX5PF55OLG0v39mPQRZ4cp7klFpLtOsUqWK8e677xZZdu/evfY2xc2/0lNPPWVvm5qaWt6yK5XybOPS+Pjjj+39PP/88y6uvvJwxXb+5ZdfjICAAMPX19fYu3dvoXkFfXCytHPbOCMjw95m4MCBRr9+/Uq85PjLL7/0wBp6B1d8lo8cOWK0adPG4fKdOnUylixZ4sa18i7l/TyuXLnSPv/rr78ucawBAwYY0uXbFcD1yr1HyGq1qkePHlqwYIH27dsnm82mzMxMxcTEaPr06apevbqys7M1btw4RUVFFVr24sWL9umCY9KOVK1a1T5d8GRwsyjPNr6agwcP6oknnpB0eRfsCy+8UBGrUCm4Yjs//vjjyszM1Pjx43XTTTe5eQ28X3m28YULF+zT33zzjVatWqXOnTtr69atunTpkpKSkvTRRx8pNDRUmZmZevjhh7Vv3z53r6JXcMVnuXnz5lqxYoXuvPPOYuefPXtWx48fV25ubkWuitcq7+fRmd8/s/32uU1FJ63Dhw/b71MTFhZmXLhwwT5v27Zt9kT80UcfldjPlZdznj17tqLLrlRK2sYlSUhIMP7whz/Y/zrctm1bBVdauV1tO3/00UeGJKNRo0ZGenp6keULPr9m3iN0NSVt4zNnzhT6K7tt27ZGZmZmkT7++9//2i9J7tu3rzvLrzRK850xbdo0w2q1GiEhIcbs2bONX375xUhOTjYOHjxoTJkyxfD39zckGd27dzcuXrzogbXwrPJ+Hj/77DP7st9++22JYw0dOtT+PQ3Xc8utV+fOnWv/B7/yPgtlOTT29NNPm/bQWGk42saOXLhwwWjXrp0hybBaraY+jFAWjrZzfHy8ERoaakgyVq1aVeyyBKHScbSNL1y4UOiHp6TP7L333mtIMvz9/Y1Lly65o+xKp6TvjJkzZ9oP6ezbt6/Y5desWWNffuLEie4o2auU9/NYlkNjBXee5tBYxXDL5fP9+/e3T1951nutWrXs01detVScc+fOSbp8BVm1atVcW+A1wNE2Lk5GRoZ69+6tPXv2yGKx6KOPPtIDDzxQwRVeGxxt5xdeeEHnz59X//791bdvXw9Udu1wtI2rVatmv42GdPmSY0e6du0qScrKyir3hQTXKkfbOScnR9OmTZMkDR48WG3atCl2+V69eqlbt26SpAULFlRcoV6qvJ9HZ37/atas6XS9cMwtQejKe0ykpKTYp+vXr28PNcePHy+xj5MnT0q6fNy6pHtbmJWjbfx7WVlZ6t+/v7Zu3SpJmjNnjv1mirg6R9v5xIkTkqSVK1c6fLhlgUWLFtnfW7hwobtKrzQcbWOr1VroxqChoaEO+7hyXmpqqmsLvEY42s4HDx7U+fPnJcnhvd0KFMxPTEy86o/5taa8n8crly3t7x9X9FYMtwSh+Ph4+/TvPyzt27eXJP3www8Ol8/Ozrb/xVLQHoWVtI0L5OTk6IEHHtCGDRskSdOnT9fYsWPdUt+1ojTbGeVT0ja+8ofZZrM57OPKeSEhIa4r7hriaDtfunTJPn21PzqvnG/GP1DL83msVauWGjduLKnk37/Tp0/r7Nmzkvj9qyhuCULLly+3TxfcqKtAnz59JF3+i/rHH38sdvnVq1crMzNTkjjs4EBJ21iS8vLyNHToUH399deSpBdffFETJ050W33XCkfb+aOPPtJPP/1U4qtAnz597O/xeS6qpM/ygAED7NNbtmxx2MfmzZslSUFBQWrWrJlrC7xGONrO4eHh9undu3eX2EfBfXSqVatmysM25f08Fvz+fffdd4WC6ZW+/PJL+zTfFxWkvCcZ/frrryXO//nnn42QkBCHVydc+dDVO++8s9iHrrZs2dKQZDRu3NiUD10t7zbOz883hg8fbj8x78knn6zIciut8m7nqxEnS5d7G+fk5NgfwtyqVatir1b6z3/+Y1gsFlNv6/Ju52bNmtlPlj5w4ECxfVz5IOEBAwa4rPbKpLyfx4MHD9qvKBsxYkSRZRMSEow6derY79uEilHuIFSzZk1jwIABxsKFC42ff/7ZSExMNGw2m/Hjjz8af//73+1PNZdkLFq0qNg+3nrrLXube++919i1a5eRmJhobNmyxejUqZN93ldffVXeciul8m7jsWPH2ucPHTrUSEtLK/GVk5PjgbX0PFd8lktCEHLNNl6/fr3h4+NjSDI6dOhgrFu3zkhKSjJOnTplvPPOO/Y/rMLCwozY2Fg3r6F3KO92vvLS7rCwMGPOnDnGsWPHjPPnzxuHDh0ypk6dagQEBNgv6f7pp5/cv5Jeoryfx3Hjxtm39YgRI4wDBw4YCQkJRnR0tBEREWFIMvz8/Izt27d7YO3ModxBqEaNGg7vplnwCgwMND788MMS+7nyw/D7l9VqNWbOnFneUiut8m7jqy37+1dUVJR7V9BLuOqz7AhByHXb+OOPP7bfx6a4V926dU39w+GK7Txjxgz7D7yjV3BwsLFs2TI3rpl3Ks/nMScnx355fHGvgIAAY/HixW5eI3OxGEb5Hty1YsUKbd26VTt27FBcXJxsNpuysrIUEhKili1bqnv37ho1alSpHjy5bt06vf/++9q5c6eSk5NVp04ddenSRePHj9ett95anjIrtfJu47KexBgVFaVHHnnEBZVXLq78LBen4N9h+PDhpr1azJXb+PDhw5ozZ47Wr1+vs2fPys/PT82aNVPfvn01btw4hYWFuWGNvJOrtvPBgwc1f/58bdmyRSdPnlRGRoaCg4PVrFkz3XXXXRo9erQaNGjgprXybuX9PC5ZssR+J/DU1FTVq1dP3bt319NPP62WLVu6aS3MqdxBCAAAoLJyy1VjAAAA3oggBAAATIsgBAAATIsgBAAATIsgBAAATIsgBAAATIsgBAAATIsgBAAATIsgBAAATMu3pJlBQUHKzMyUj4+P6tSp466aAABAGSUkJCgvL08BAQG6ePGip8upNEp8xIaPj4/y8/PdWQ8AACgHq9WqvLw8T5dRaZS4R+h/Qcgif98glw2anZshSariG+iyPq+UW71yHfGzZpXtoaillZORJknyCwx2ed/5JX5yvItPfr5qp13eFqrpI/m4tv9ztstfOHVrurDjPEn/v9/UmgHK96mYz0hFyE1wfZ/ZypQkVVGA6zuXVLVu5frRSMupmO2QdyFdkuRTo5rL+/ZNznF5nxXO1/VfdNm5l/fUVHHhb2qBrNx0SYZ8fFz8JXeNK/FfuU6dOjpz5oz8fYN0e9O/uWzQrac+liR1bjzSZX1e6egrIRXSb0UJ3l61Qvo98tkMSVKLoc+7vO/U6yvPnsLrUlK0/ZXXJEn56xtK4a79crux22lJ0v4tjVzX6dlcWdvHSpImf3qXUupWzB8NFeFw+1yX97ndWC9J6mS5y+V9S9J9WyogvVWgt37uXiH9nn76XUlSo1njXN53k0E/u7zPimZtGeHyPrcd/UCSdFvz0S7ve8vhd5SVm8apLGVUuXadAAAAuBBBCAAAmBZBCAAAmBZBCAAAmJZHrv2pqJOkUVhFnCSNolx6kjSKVVEnSaOwijhJGoVVxEnSKB/2CAEAANMiCAEAANMiCAEAANMiCAEAANMiCAEAANMiCAEAYAKxsbGyWCyleu3evbvEvtatW6d+/fopPDxcAQEBatSokYYOHaodO3a4aW1chyAEAABKbfz48brnnnu0evVq/fbbb8rKytKvv/6qxYsX67bbbtM//vEPT5dYJgQhAABMJjo6WmlpaQ5f7dq1K3a5WbNmac6cOZKk3r17a+fOnUpMTNTmzZvVsWNH5eXl6bnnntPy5cvduTrl4pEbKgIAAM+pWrWqqlWrVqZlkpKSNGXKFEnSn//8Z61evVpW6+X9Kd26ddN//vMf3XzzzTpy5IieeeYZ3XvvvapSpYqrS3c59ggBAICr+uSTT5SWliZJmjFjhj0EFahataqmTp0q6fL5SNHR0W6v0RkEIQAAcFWrV6+WJDVt2lS33HJLsW369esnf39/SdKqVavcVlt5EIQAADCp7OzsUrfds2ePJKlTp04O2/j7+9vPLypo7+0IQgAAmMzYsWMVHBwsf39/+fv7KzIyUuPHj9exY8eKbX/mzBn7YbHrr7++xL6bNm0qSTp69KgMw3Bt4RWAIAQAgMkcPHhQ6enpki7vFTp06JDmzJmjyMhIzZ07t0j7pKQk+3TdunVL7LtgfmZmpn0Mb8ZVYwAAVCLbjn5Q7PvZuRdLXM5qtapHjx4aPHiwOnTooAYNGigoKEixsbFasWKFpk+frtTUVI0bN05BQUEaMWKEfdmLF//Xd0BAQInjVK1a1T6dnp6u4ODg0qyWxxCEAAAwgUaNGmn9+vVF3m/RooUmTpyo/v37q3PnzrLZbHr22Wd13333qXr16kXaWyyWEse52nxvQxACAKASua356GLf33L4HWXlpjndb0REhF555RWNHTtWycnJio6O1uDBgyVJQUFB9naXLl0qsZ8r55f1XkWewDlCAABAktS/f3/79JVXfdWqVcs+nZCQUGIf586dk3T5CjKCEAAAqDTq1Kljn05JSbFP169f3x5qjh8/XmIfJ0+elCQ1b968UhwmIwgBAABJUnx8vH06NDS00Lz27dtLkn744QeHy2dnZ9v3JBW093YEIQAAIEmFHpb6+wev9unTR5J04sQJ/fjjj8Uuv3r1amVmZkqS+vbtW0FVuhZBCAAAE4iLiytx/v79++0PVQ0LC1PPnj0LzR8+fLj9Uvjnn39e+fn5heZfunRJkydPliQ1btxYvXv3dlHlFYsgBACACbRt21YDBw7UokWLtH//fiUlJSk5OVl79uzR5MmT1alTJ/t5QW+//XaRS+dr1aplD0obN25Uv379tHv3biUlJem7777TnXfeqcOHD0uS3nrrrUrx5HmJy+cBADCF3NxcrVixQitWrHDYJjAwULNnz9awYcOKnf/0008rNjZW7777rr755ht98803heZbrVbNmDFD9913n0trr0gEIQAATCAqKkpbt27Vjh07FBcXJ5vNpqysLIWEhKhly5bq3r27Ro0apXr16pXYz5w5c9S7d2+9//772rlzp5KTk1WnTh116dJF48eP16233uqmNXINghAAACYwYMAADRgwwCV93X333br77rtd0pencY4QAAAwLYIQAAAwLYIQAAAwLYIQAAAwLYIQAAAwLYIQAAAwLYIQAAAwLYIQAAAwLYIQAAAwLe4sDXNJyPV0BaXzW459snriJQ8WUna1jFwlK0D5Fv7OAuD9CEIwFWvPOE+XUGbPDtvg6RLKbIh6KUmBni4DAK6qdEEoN095x05WcCmu03xsqKdLKJMj7zbxdAlldsNffvJ0CaVWy8jwdAmm0/LfFl2oa/F0GaUWNbWvp0sok6f+/rWnSyizuctv93QJZVZ/4EFPl1A2RiXZ4+1l2COEa16yAjREvRT3XHtPl1JqtdNStfyDdyRJ+V/Xl8L9PFxRKSTkVso9bgDMjSCEa16+xaokBSq+RoinS3FOuJ8Uzv+qAFAROJsRAACYFkEIAACYFkEIAACYFkEIAACYFkEIAACYFkEIAACYFkEIAACYFkEIAACYFkEIAACYFkEIAACYFkEIAACYFkEIAACYFkEIAACYFkEIAACYFkEIAACYFkEIAACYFkEIAACYFkEIAACYFkEIAACYFkEIAACYFkEIAACYFkEIAACYFkEIAACYFkEIAACYFkEIAACYFkEIAACYFkEIAACYFkEIAACYFkEIAACYFkEIAACYFkEIAACYFkEIAACYFkEIAACYFkEIAACYFkEIAACYFkEIAACYFkEIAACYFkEIAACYFkEIAACYFkEIAACYlq+nCwBwFQm5nq6gdH7LsU8GJ17yYCFlVycjRbaAYOVZfTxdCgA3IwgBXs7aM87TJZTZUw//x9MllNEa9en/khICQzxdCAA3uyaDUN75854uoUxajPN0BWWX5+kCnNDk79s9XUKp1TIyPF2C6VRbuUeZlkBPl1Eqi9TH0yWU2eRXPvd0CWW2QE09XQLc4JoMQkBll6wADVEvxU1o7+lSSq12WqqWz3tHkpT/dX0p3M/DFZVCQm6l3OMGwHUIQoAXyrdYlaRAxdcI8XQpzgn3k8L5egHg/bhqDAAAmBZBCAAAmBZBCAAAmBZBCAAAmBZBCAAAmBZBCAAAmBZBCAAAmBZBCAAAmBZBCAAAmBZBCAAAmBZBCAAAE4iNjZXFYinVa/fu3UWWz83N1YYNG/Tss8+qc+fOql27tvz8/BQSEqL27dtr4sSJOnXqlAfWrHx4GBAAALiqdu3aaf/+/UXev3Dhgvbs2aM9e/bo3Xff1fvvv6/hw4d7oELnsEcIAACTiY6OVlpamsNXu3btiiyTmpoqi8WiHj166MMPP9SBAwdks9l04sQJvffee6pZs6YyMjI0YsQIRUdHe2CtnMMeIQAATKZq1aqqVq1amZZ54IEHNGrUKLVo0aLQ+2FhYfq///s/3XHHHerQoYMuXryoCRMmqFevXq4sucKwRwgAAFzVzJkzi4SgK0VERGjEiBGSpIMHD+r06dPuKq1cCEIAAMAlWrdubZ8+c+aMByspPYIQAAAmlZ2d7dL+EhIS7NPVq1d3ad8VhSAEAIDJjB07VsHBwfL395e/v78iIyM1fvx4HTt2rFz9Llu2TJIUGhqqiIgIV5Ra4ThZGgCASmS7sb7Y97OVWeo+Dh48+L/lsrN16NAhHTp0SB988IHeeustjR07tsx1RUVFad++fZKkxx9/XD4+PmXuwxPYIwQAgAlYrVb16NFDCxYs0L59+2Sz2ZSZmamYmBhNnz5d1atXV3Z2tsaNG6eoqKgy9X3w4EE98cQTkqTGjRvrhRdeqIhVqBDsEQIAoBLpZLmr2Pe/N9YoS5ccLteoUSOtX190b1KLFi00ceJE9e/fX507d5bNZtOzzz6r++67r1Tn+SQmJqpfv35KT09XlSpVtHjxYtWoUaP0K+Rh7BECAACKiIjQK6+8IklKTk4u1U0RU1NTdc899+j48eOyWq369NNP9ac//amiS3UpghAAAJAk9e/f3z69Z8+eEttmZGSod+/e2rNnjywWiz766CM98MADFVyh6xGEAACAJKlOnTr26ZSUFIftsrKy1L9/f23dulWSNGfOHPvNFCsbghAAAJAkxcfH26dDQ0OLbZOTk6MHHnhAGzZskCRNnz7dqavMvAVBCAAASJKWL19uny7uwat5eXkaOnSovv76a0nSiy++qIkTJ7qtvopAEAIAwATi4uJKnL9//35NmTJF0uUHqfbs2bPQfMMw9Oijj2rp0qWSpCeffFKvvfZahdTqTlw+DwCACbRt21Zdu3ZVv3791K5dO9WrV09Wq1WxsbFauXKlZs2apYsXL0qS3n777SKXzj/xxBNatGiRJGno0KF69dVXlZ6e7nC8gIAA+fp6f8zw/goBAEC55ebmasWKFVqxYoXDNoGBgZo9e7aGDRtWZN7cuXPt05999pk+++yzEseLiorSI4884nS97kIQAgDABKKiorR161bt2LFDcXFxstlsysrKUkhIiFq2bKnu3btr1KhRqlevnqdLdSuCEAAAJjBgwAANGDDA6eUNw3BhNd6Dk6UBAIBpEYQAAIBpEYQAAIBpEYQAAIBpEYQAAIBpEYQAAIBpEYQAAIBpEYQAAIBpEYQAAIBpcWdpAK6XkOvpCkrntxz7ZJguSZXkxrkBGSmyBQQrz+rj6VKASo8g5AXyzp/3dAll5ntdXU+XUGYxM8M9XUKZBe+0eLqEUgtI+1+t1p5xHqzEOe9pk6dLKL2V0Xpj/T1KrVvV05WU2oLmTT1dQpmN+eWop0sok59uy1XWOU9XUflwaAwAAJgWe4QAuERSULB6jJisWlG7PV1KqYXpkn1PUP7X9aVwPw9XdBUJuZVybxvgzQhCAFwiz+qjc8EhkiXQ06WU3pXnBIX7SeF8JQJmw6ExAABgWgQhAABgWgQhAABgWgQhAABgWgQhAABgWgQhAABgWlwrCgAAKqW0tDT99NNPkqSuXbs61QdBCAAAVEqHDh3S7bffLqvVqtxc555xyKExAABQqRmG809MJggBAADTIggBAADT4hwhAADgdj4+Pp4uQRJBCAAAeEB5zutxJYIQAABwOx8fH+Xn5+umm27STTfd5FQfiYmJio6OLlcdBCEAAOB2rVq10oEDB9SyZUtFRUU51ceOHTvKHYQ4WRoAALjdH//4RxmGoZ07d3q0DoIQAABwuz/+8Y+SpBMnTiglJcVjdRCEAACA2xUEIUlO7xXy9/dXo0aN1LhxY6fr4BwhAADgdjfeeKM2bdokSWrevLlTfbRt21axsbHlqoMgBAAA3M5qtapbt26eLoNDYwAAwLwIQgAAwLQIQgAAwLQIQgAAwLQIQgAAwLQIQgAAwLQIQgAAwLQIQgAAwLQIQgAAwLQIQgAAwLQIQgAAwLQIQgAAwLR46CoAAPAa3333nX26a9euLmvrCEEIAAB4jdtvv10Wi0UWi0W5ubkua+sIQQgAAHgVwzAqpG1xCEIAAMBrvPzyyxXS1hGCEAAA8BruDkJcNQYAAEyLIAQAALzCHXfcoTvuuEMbNmxw25gcGgMASUpw7ooTt/otxz4ZnJjpwULKrpZhVbIClG/h72849v333ys/P19RUVFuG5MgBACSrD3jPF1CmYwZutnTJZTZEPVSkgI9XQa8WN26dfXbb78pODjYbWMShOCU3Phzni6hzJo/dsHTJZTZkfmtPF1CmVnG/snTJZReeooUFe3pKkzjxnX5Sq2b7+kySu3V6cM9XUKZpKZNlVT5vueu1KFDB3399dc6fPiwbrvtNreMSRACYFq2wGD1GDFZmbXKdx8Sd6mdlqrlH7wjScr/ur4U7ufhikohIbfS7W2D5/ztb3/T6tWr9eabb2rVqlVuGZMgBMC08qw+SqgWoowalSMIFRLuJ4XzFY5ry913360XX3xRr7/+uoYOHaq33npL1113XYWOyf9FAADAK4wcOVKSVL9+fS1ZskRLly5V27Ztdf311ysw0PH5ZRaLRQsWLHBqTIIQAADwCgsXLpTFYpF0+dEZubm52r17t3788UeHyxiGQRACAACVX9euXe1ByF0IQgAAwCts3rzZ7WNyZysAAGBaBCEAAGBaHBoDAABe68CBA4qNjVVaWpqCg4PVpEkTtW7d2mX9E4QAAIBXSU1N1WuvvaaPP/5Y58+fLzI/NDRUo0aN0qRJk1S9evVyjcWhMQAA4DWOHDmiNm3a6K233lJycrIMwyjySk5O1syZM3XTTTfpl19+Kdd47BECAABe4dKlS+rZs6dOnz4tSbrnnns0aNAgRUZGKjg4WOnp6Tpw4ICWLl2q6OhonTp1Sj179tSBAwcUEBDg1JgEIQAA4BXef/99xcbGyt/fX4sXL9aAAQOKtGnfvr2GDx+uVatWafDgwTp58qTef/99Pf30006NyaExAABMIDY2VhaLpVSv3bt3l7rfxMRE1apVy77sI4884nSNy5cvl8Vi0aRJk4oNQVfq16+fJk2aJMMwtHz5cqfHJAgBAACnPfnkk7LZbC7pKyYmRpI0ZMiQUrUvaHf48GGnx+TQGAAAJhMdHa0uXbo4nF/SA06v9O9//1uLFy/W9ddfrxMnTpS7rosXL0qSatasWar2Be0KlnMGe4QAADCZqlWrqlq1ag5fVuvV48HFixc1evRoSZfP7XGFWrVqSSr9Hp6CdrVr13Z6TIIQAAAos5deekmnTp3SoEGDdPfdd7ukz06dOskwDE2fPr1U7adPny6LxaKOHTs6PSZBCAAAlMmuXbs0Z84c1ahRQ2+//bbL+h05cqSky4fuBg0apHPnzhXbLjExUUOGDNGaNWskSaNGjXJ6TM4RAgDApLKzs1WlSpUyLZObm6vHHntM+fn5mjZtmurVq+eyenr27KkhQ4bo888/11dffaWVK1eqS5cuatWqlf0+QgcPHtTWrVuVk5MjSXrooYfKtUeKIAQAgMmMHTtWp06dUnp6uqpUqaIbbrhB3bt317hx43TDDTeUuOzMmTO1b98+3XrrrfZzhFxp4cKFql69uubPn6+cnBxt2rRJmzZtKtTGMAxJ0ujRo/XOO++UazyCEAAAlcihZW8W+37OpbRS93Hw4EH7dHZ2tg4dOqRDhw7pgw8+0FtvvaWxY8cWu9yxY8c0depU+fr6av78+aU6qbqs/Pz8NG/ePP3tb3/TRx99pO+//16nTp0q9NDVLl266NFHH1WbNm3KPR5BCAAAE7BarerRo4cGDx6sDh06qEGDBgoKClJsbKxWrFih6dOnKzU1VePGjVNQUJBGjBhRpI/HH39cmZmZeuaZZ3TTTTdVaL1t2rTRnDlzKnQMiSAEAECl0uq+CcW+v//zqcrJuOBwuUaNGmn9+vVF3m/RooUmTpyo/v37q3PnzrLZbHr22Wd13333FXqy+4IFC7Rp0yY1atRIr7zySvlXxEtw1RgAAFBERIQ94CQnJys6Oto+79y5c3ruueckSe+++66CgoI8UmNFYI8QAACQJPXv399+ftCePXs0ePBgSdILL7yg8+fPq3///urbt6/b6jlz5ozi4+OVkZFhP0Haka5duzo1BkEIAABIkurUqWOfTklJsU8XPD5j5cqVslgsJfaxaNEiLVq0SJIUFRVV5oewZmRkaNq0aYqKilJ8fHyplrFYLMrNzS3TOAUIQgAAQJIKBY/Q0FC3j5+WlqZu3bpp3759V90D5CoEIQAAIElavny5fbpdu3b26Y8++kjp6eklLnvzzTdLkvr06aOpU6dKunyCdlnMmDFDe/futfczYsQItWjRotQPgXUGQQgAABOIi4tTgwYNHM7fv3+/pkyZIkkKCwtTz5497fOudpPFK4WFhalt27ZO1fjVV1/JYrFo9OjReu+995zqo6wIQgAAmEDbtm3VtWtX9evXT+3atVO9evVktVoVGxurlStXatasWbp48aIk6e233y506by7nDp1SpI0fvx4t41JEAIAwARyc3O1YsUKrVixwmGbwMBAzZ49W8OGDXNjZf8THBwsm81W6KTtikYQAgDABKKiorR161bt2LFDcXFxstlsysrKUkhIiFq2bKnu3btr1KhRLn2Ialm1bdtWGzdu1IkTJwqdo1SRCEIAAJjAgAEDNGDAgArr3xVXeY0dO1bffvut/vnPf2revHkuqOrquLM0AADwCn379tX48eP14Ycf6o033nDLJfTsEQIAAG5XcIn974WGhqpp06Z68cUX9cEHH6hHjx4KDw+Xj49Pif1NnjzZqToIQgAAwO2mTJlS4l2qDcPQ6dOn9fHHH5eqP4IQAACoNBo1anTVx3W4A0EIAAC4XWxsrKdLkMTJ0gAAwMQIQgAAwLQ4NAYAALyCYRj69ddfJUkNGzYs8Ryi/Px8xcXFSSr7w12vRBACgMooIdfTFZTObzn2yeDETA8WUnZ1LqbIVjVYedaSL9uG66xbt069e/dWq1attH///hLbWq1W9e7dW4cOHdK6devUvXt3p8YkCAFAJWTtGefpEsps3F82e7qEMvq3eg7+uxKCQjxdiGl8+eWXMgxDw4cPL1X7ESNG6Nlnn9WXX35JEAKuJj+zcv01Kkktxv7i6RLK7Pg/m3q6hDJrOvhnT5dQKrWMDE+XYDohS35UriXQ02WUitXI9nQJ5bZr1y5ZLBb9+c9/LlX7gnY7duxwekyCEABUEskK0BD1Utzz7T1dSqnVTk3V8nnvSJLyv64vhft5uKJSSMitlHvcrgUF5/w0bVq6P6gaN24sSTp79qzTYxKEAKCSyLdYlaRAxdcI8XQpzgn3k8L52YFj2dmX92rl5eWVqn1Bu/T0dKfH5PJ5AADgFerWrStJOnDgQKnaHzx4UJJUu3Ztp8ckCAEAAK/QsWNHSdI///nPUrX/8MMPJUm33nqr02MShAAAgFf4y1/+IsMw9MUXX2jWrFkltp09e7aWLFkii8Wiv/zlL06PycFaAADgFXr16qW77rpL69ev13PPPaeVK1dq+PDhatu2rYKDg5WWlqa9e/fqk08+0datWyVJd955p/r16+f0mAQhAADgNZYsWaKePXtqx44d2rZtm7Zt21ZsO8Mw1LFjRy1durRc43FoDAAAeI2QkBB99913euONN1SvXj0ZhlHkFR4erpkzZ+q7775TjRo1yjUee4QAAIBX8fPz04QJEzRhwgQdPnxYx48fV2pqqqpXr64bbrhBERERLhuLIAQAALxWy5Yt1bJlywrrn0NjAADAtAhCAADAtDg0BgAAvMqRI0e0aNEi7dq1S/Hx8crIyJBhGA7bWywWHT9+3KmxCEIAAMBrTJs2TVOmTFFeXl6J4edKFovF6fEIQgAAwCssW7ZML730kiSpatWq6tGjh1q0aKHAwMAKG5MgBAAAvMLcuXMlSTfeeKPWrl2r8PDwCh+Tk6UBAIBX+Omnn2SxWDR79my3hCCJIAQAALxEbm6uJKlt27ZuG5MgBAAAvELTpk0lSampqW4bkyAEAAC8wgMPPCBJWrt2rdvGJAgBAACv8Oyzz6pFixZ6+eWX9csvv7hlTK4aAwAAXiEpKUlRUVEaOnSoOnTooCeeeEL33HOPwsPD5ePjU+KyjRo1cmpMghAAAPAKBecISZJhGJo2bZqmTZt21eUsFov9ROuyIggBAACv8Ps7SZf2ztLlQRACAABeYdOmTW4fkyAEAAC8Qrdu3dw+JleNAQAA0yIIAQAA0yIIAQAA0+IcIQAA4FUSEhI0b948bdiwQUeOHNGFCxeUl5fnsD2XzwMAgGvCxo0bNWjQIJ0/f57L5wEAgHnExcVp4MCBSktL02233aaHHnpIY8aMkcVi0XvvvafMzEzt379fK1eu1Pnz5xUZGamnn35aVqvzZ/oQhAAAgFeYPXu20tLSdMstt2jLli2yWq0aM2aMJGnYsGEKDAyUJM2ZM0fjxo3TwoUL9e233+qzzz5zekxOlgYAAF5hw4YNslgseuqpp0rcyxMUFKSPP/5YvXr10pIlS/T55587PSZBCAAAeIXY2FhJUvv27YvMy8rKKvLehAkTZBiGPv74Y6fHJAgBAACvcOnSJUlS7dq17e8VHA5LSUkp0r5169aSpP379zs9JkEIAAB4hbCwMEmSzWazv3fddddJkmJiYoq0T0pKklR8SCotghAAAPAKLVu2lCT99ttv9vcKDpN99dVXRdovWbJEklSnTh2nxyQIAQAAr9CjRw9J0t69e+3vDRkyRIZhaOHChXrxxRe1f/9+7d27V6+88opef/11WSwW9ezZ0+kxCUIAAMAr9O3bV4ZhaNWqVfb3+vfvr7vuukuGYeiNN95Q27Zt1b59e02dOlU5OTmqWbOmXnrpJafHJAgBAACv0Lp1a+3du1ezZs0q9P6KFSv017/+Vf7+/jIMw/7q1q2bvv/+ezVs2NDpMbmhIgAA8Bpt2rQp8l7VqlU1b948zZo1SzExMcrKylLTpk1Vt27dco9HEAIAuEeCcw/FdLvfcuyTYbokVfzjrlzCWlkKLYeqVavq5ptvdmmfBCEAgFtYe8Z5uoQye0+bPF1CqTWQdMbTRVRCBCHAi+WnpXm6hDK74aXKV3OepwsooyYvbvd0CaVWy8jwdAlAiQhCAIAKk6wADVEvnZzq2sMZFan2hVR9/da7kqT8r+tL4X4erqgUEnKlSrjHzRsQhAAAFSbfYlWSAhUfGuLpUpwT7ieF81N5LePyeQAAYFoEIQAAYFoEIQAAYFoEIQAAYFoEIQAAYFqcCg8AALzWyZMnlZiYqMzMTHXt2tXl/ROEAACAV0lISNDrr7+uxYsXKzk5WZJksViUm/u/x7QcPXpUzz77rPz9/fX555/L19e5SEMQAgAAXuPHH39Unz59dO7cORmG4+enNW/eXL/88ouOHj2qtWvXqk+fPk6NxzlCAADAK6SkpOjee+9VfHy8brjhBi1cuFA7d+502P7BBx+UYRiKjo52ekyCEAAA8Apvv/22zp07p5YtW2rXrl0aNmyYWrZs6bB9t27dJEm7du1yekyCEAAAJhAbGyuLxVKq1+7du6/a37Zt2zRq1Cg1a9ZMQUFBqlGjhiIiIjR48GB98MEHTtW4evVqWSwWTZ06VdWrV79q++bNm0u6fEK1szhHCAAAlFpWVpb++te/atGiRUXmpaam6siRI/riiy80evToMvd94sQJSVLnzp1L1b4gLKWlpZV5rAIEIQAATCY6OlpdunRxOD8wMLDY9/Py8jRw4EBFR0fLYrFo+PDheuSRRxQRESGr1aoTJ05o7dq1+vTTT52qKycnR5JUpUqVUrUvCEBBQUFOjScRhAAAMJ2qVauqWrVqZV5u1qxZ9hC0ePFiDR48uND82rVr69Zbb9WUKVOcquu6667TqVOndPz4cXXo0OGq7ffs2SNJatSokVPjSZwjBAAASiElJcUecEaOHFkkBLnCbbfdJkn6/PPPS9V+/vz5slgs9pOmnUEQAgAAV/Xpp58qIyNDkvTUU09VyBijRo2SYRiaO3euNmzYUGLbGTNm2C+bf/zxx50ek0NjAACYVHZ2dqnPxykIHeHh4YqMjLS/n5+fL8Mw5OPjU+56unXrpr/85S/69NNP1atXLz300EO64447CtVw7NgxLVmyRDt27JDFYtHYsWPVunVrp8dkjxAAACYzduxYBQcHy9/fX/7+/oqMjNT48eN17Ngxh8sU3KunVatWMgxD8+fPV7t27RQQECA/Pz81bNhQo0aN0tGjR8tV20cffaQHH3xQeXl5+vTTTzVy5EhZLBZJUp8+ffTUU0/phx9+kGEYGjp0qGbNmlWu8QhCAABUIjd2O1309cAZnStDHwcPHlR6erqky3uFDh06pDlz5igyMlJz584t0v7SpUtKSkqSdPmS9QEDBmj06NH66aeflJOTI8MwFBcXpwULFuimm27S0qVLnV6/KlWqaMmSJVq+fLm6dOkiX19fGYZhf1ksFnXq1ElfffWVPvnkk3LviSIIAQBgAlarVT169NCCBQu0b98+2Ww2ZWZmKiYmRtOnT1f16tWVnZ2tcePGKSoqqtCyFy5csE9/8803WrVqlTp37qytW7faQ9JHH32k0NBQZWZm6uGHH9a+ffvKVW///v21efNmpaSkaP/+/dq6dav27t2r5ORkbdu2TQMHDixX/wUsRglPNGvQoIHOnDkjf1VVF0tvlwwI4Nrmc0NTT5dQZnnHnL8rLUrnlzm3erqEUrvufIp+mPy6JCn/xyZSeCU4nfZsrhq1j9UZSfXr11dcXFyZu4iJiVHnzp1ls9kUFhamkydP2m9YePbsWdWvX9/etm3btvrhhx/k7+9fqI/t27erc+fOys/PV9++fbVq1apyrZY7sEcIAAAoIiJCr7zyiiQpOTm50INMf3/PoUmTJhUJQZLUqVMn9erVS5K0bt06ZWZmVmDFrkEQAgAAki4fjipQcLNC6XIQujL4lHRX6q5du0q6/CiOkk6+9haVYH8fAABwhzp16tinU1JS7NNWq1UtWrTQzz//LEkKDQ112MeV81JTUx22u/Ky+PKyWCzauHGjU8sShAAAgCQpPj7ePv37sHPLLbfYg5DNZlN4eHixfdhsNvt0SEiIw7E2b94si8WiEk5VLrWCy+udQRACAACSpOXLl9un27VrV2jegAEDtGDBAknSli1bNGTIkGL72Lx5s6TLD0Jt1qyZw7GGDRtWrgDjKgQhAABMIC4uTg0aNHA4f//+/fZniYWFhalnz56F5t99991q0aKFjhw5otdee039+vUr8pT6TZs2ad26dZKk+++/X35+fg7HW7hwoXMr4mKcLA0AgAm0bdtWAwcO1KJFi7R//34lJSUpOTlZe/bs0eTJk9WpUyf7eUFvv/22/dL5Ar6+vnr33Xfl4+OjQ4cOqVu3blq/fr1sNptOnz6tOXPmqF+/fjIMQ2FhYfYr0Lwde4QAADCB3NxcrVixQitWrHDYJjAwULNnz9awYcOKnd+jRw/985//1N/+9jft3r1bd999d5E2devW1cqVK9W4cWOX1V6RCEIAAJhAVFSUtm7dqh07diguLk42m01ZWVkKCQlRy5Yt1b17d40aNUr16tUrsZ8RI0aoY8eOmjNnjtavX6+zZ8/Kz89PzZo1U9++fTVu3DiFhYW5aa3KjyAEAIAJDBgwQAMGDHBJXy1bttS8efNc0teVpk6dWuZlfH19Vb16dTVo0EDt27dXw4YNy7Z8mUcEAACoAFOmTCn3lWQdO3bUa6+9pj//+c+las/J0gAAwCs0atRIjRo1Uo0aNQo9cb5GjRqqX79+se83bNhQoaGh9ve2b9+u7t276/333y/VmAQhAADgFWJjY/XBBx/IarWqQYMGmj9/vuLj45WcnKzTp08rOTlZ586d0/z589WoUSP5+Pho/vz5SkpKks1m08cff6wGDRrIMAyNHz9ehw8fvuqYBCEAAOAVYmJidP/996t27dr66aef9NhjjxV67Ick1a5dW4899ph+/PFH1apVS/fff79iYmIUGhqqRx55RLt27VLDhg2Vn5+vuXPnXnVMghAAAPAKM2fOVEZGhqZPn66aNWuW2LZmzZqaPn26Ll68qBkzZtjfr1u3riZNmiTDMLRp06arjkkQAgAAXuHbb7+VJN12222lal/Q7j//+U+h97t37y5JOnPmzFX7IAgBAACvkJCQIOnyzR9Lo6BdwXIFatWqJUnKzs6+ah8EIQAA4BUKbsS4YcOGUrUvaPf7GzheuHBBkq56eE0iCAEAAC9xxx13yDAMTZw4UceOHSux7fHjx/XCCy/IYrHojjvuKDTvxx9/lCSFh4dfdUxuqAgAgCMJpTtE43GVpc6rmDRpkpYuXapz586pXbt2Gjt2rPr27asWLVqoWrVqunjxoo4cOaJVq1bpvffeU1pamqpUqaIXXnihUD+LFy+WpFLdVJEgBACAA9aecZ4uwVRatmypzz77TEOHDlV6erpmzJhR6IqwKxmGIT8/P/3rX/9Sq1at7O+fP39eOTk56t27tx544IGrjkkQAuBSecdOerqEMrP4VfF0CWXyS1Skp0sos+o7fTxdQqkFp1WeWq9F9913nyIiIvT888/r3//+t/Lz84u0sVqtuueeezRjxgy1bt260LzQ0FCtXLmy1OMRhAAAuEJSULB6jJysS3UNT5dSJolzZ0tpaZ4uwyUiIyP1zTffKCEhQdu3b1dsbKzS09NVrVo1NW7cWJ06dVLdunVdMhZBCACAK+RZfXQuOEQZNSpXEMqzXHvXP9WpU0f9+vWr0DGuva0GAABQSgQhAABgWhwaAwAAXuX8+fNaunSpdu3apfj4eGVkZMgwHB+qtFgs2rhxo1NjEYQAAIDX+PTTTzVmzBilp6dLUokBqIDFYnF6PIIQAADwCps3b9bw4cPt4adNmzZq0aKFAgMDK2xMghAAAPAKb775pgzDUKNGjbRixQrdfPPNFT4mJ0sDAACvsHPnTlksFs2ZM8ctIUgiCAEAAC9x8eJFSVLnzp3dNiZBCAAAeIWGDRtKkjIzM902JkEIAAB4hYK7SG/evNltYxKEAACAV5g4caLq1aunv//977LZbG4ZkyAEAAC8Qs2aNbVhwwZZLBbdfPPNWrBggc6cOVOqewk5i8vnAQCAV/Dx8Sn0348//niplrNYLMrNzXVqTIIQAADwChW558cRghAAAPAKUVFRbh+TIAQAALzC8OHD3T4mJ0sDAADTIggBAADTIggBAADT4hwhAADgdnfccYeky5e+b9y4sdB7ZXVlH2VFEAIAAG5X8BgNi8VS6D2LxVLmy+iv7KOsCEIAAMDtirtCbNiwYeUKNc4gCAEAALcr7p5BCxcudHsdnCwNAABMiyAEAABMi0NjAACgUkhNTVVUVJRiYmJUs2ZNPfjgg2rTpk25+iQIAQAAr/Cf//xHTz75pBo2bKg1a9YUmnf27FnddtttOn36tP29GTNmaO7cufrrX//q9JgcGgMAAF5h9erVOnDggNq1a1dk3jPPPKNTp07JMAwFBQVJkvLy8jRu3DjFxMQ4PSZBCAAAeIVt27bJYrHozjvvLPR+UlKSli1bJovFojfeeEOpqan69ddf1bJlS+Xl5WnevHlOj0kQAgAAXiE+Pl6S1KJFi0Lvb9iwQbm5uWrcuLEmTJggSQoPD9fkyZNlGIY2bdrk9JgEIQAA4BWSkpIkyX7oq8B3330ni8WiPn36FHr/1ltvlSTFxsY6PSZBCAAAeAUfHx9Jks1mK/T+999/L0nq0qVLofdDQ0MlSdnZ2U6PSRACAABeoWHDhpKknTt32t87fvy4Dh06JEnq1KlTofYpKSmSpNq1azs9JkEIAAB4ha5du8owDE2ePFkHDx5UcnKynnrqKUlSZGSk6tevX6j9wYMHJV0+X8hZ3EcIAAB4hSeeeEJRUVE6duxYoRslWiwWjR8/vkj79evXy2KxqEOHDk6PyR4hAADgFSIjI/XJJ58oKChIhmHIMAxJ0pgxY/Too48WapuTk6MvvvhCkopcbl8W7BECAABeY/DgwerZs6e+//575ebmqk2bNrr++uuLtDtz5oxGjx4tSerevbvT4xGEAACAV6lRo4buvffeEts0adJEL7/8crnH4tAYAAAwLYIQAAAwLYIQAAAwLc4RAmB6Ro7zd6X1hBbjT3m6hDKLne/8fV48pen9BzxdQpnEGdnK83QRlRB7hAAAgGkRhAAAgGkRhAAAgGkRhAAAgGkRhAAAgGkRhAAAgGkRhAAAgGkRhAAAgGkRhAAAgGkRhAAAgGkRhAAAgGkRhAAAgGkRhAAAgGkRhAAAMIHY2FhZLJZSvXbv3u2wn99++01///vfdcsttygkJER+fn4KCwtTp06dNHXqVCUmJrpxrcrP19MFAACAymHdunUaNGiQLly4UOj98+fP64cfftAPP/ygd955RytWrFDXrl09VGXZsEcIAACTiY6OVlpamsNXu3btiixz+vRp3Xfffbpw4YKqVaum119/Xfv371diYqL27Nmjp556Sr6+vkpOTlb//v0rzZ4h9ggBAGAyVatWVbVq1cq0zIcffqiLFy9KkqKionT//ffb59WqVUs333yz6tatq4kTJ+r8+fNavHixxo8f79K6KwJ7hAAAwFXt3btXkhQYGKiBAwcW2+bhhx+2T8fExLijrHIjCAEAgKsKCAiQJFksFodtfHx87NN16tSp8JpcgSAEAIBJZWdnl7ptwXlDFy9eVHR0dLFtvvjiC/t0z549y1ecmxCEAAAwmbFjxyo4OFj+/v7y9/dXZGSkxo8fr2PHjjlcZsyYMfa9PMOGDdPcuXN1+vRpZWZm6vjx45o6daomTJggSXrmmWfUsWNHt6xLeVkMwzAczWzQoIHOnDkjf1VVF0tvd9YFAHDAp2aYp0sos9j54Z4uocwa3n/A0yUUa7uxvtj3M5QmQ4bq16+vuLi4IvNjY2PVtGnTEvuuUqWK3nrrLY0dO7bY+UePHtUDDzygn3/+udj5nTp10vjx4zVo0KCrrIX3YI8QAAAmYLVa1aNHDy1YsED79u2TzWZTZmamYmJiNH36dFWvXl3Z2dkaN26coqKiiu2jefPmWrFihe68885i5589e1bHjx9Xbm5uRa6KS7FHCAAqGfYIuYe37hFy5HtjjbJ0yeEeoauJiYlR586dZbPZFBYWppMnT6p69eqF2kyfPl0vvfSSqlevrilTpqh3796qWbOmfvvtNy1dulTTp09XVlaWunfvrlWrVikwMNBVq1dh2CMEAAAUERGhV155RZKUnJxc5ITof/zjH5o0aZKqVKmiLVu2aPz48brhhhsUGhqqVq1a6eWXX9by5cslSd9++61effVVt6+DMwhCAABAktS/f3/79J49e+zTOTk5mjZtmiRp8ODBatOmTbHL9+rVS926dZMkLViwoOIKdSGCEAAAkFT43j8pKSn26YMHD+r8+fOSpFtuuaXEPgrmJyYmKiEhwfVFuhhBCAAASJLi4+Pt06GhofbpS5cu2adLuqHi7+dfra03IAgBAABJsp/jI6nQg1fDw/93svvu3btL7GPXrl2SpGrVqqlmzZourtD1CEIAAJjA1a4k279/v6ZMmSJJCgsLK3Rn6MaNG6tZs2aSpMWLF+vgwYPF9rFu3Tpt3rxZktSjRw9Zrd4fM7y/QgAAUG5t27bVwIEDtWjRIu3fv19JSUlKTk7Wnj17NHnyZHXq1Ml+XtDbb79d5NL5gpCUmZmprl276t1339Xx48eVkpKiw4cP69VXX7WfbF2lShVNnjzZjWvnPF9PFwAAACpebm6uVqxYoRUrVjhsExgYqNmzZ2vYsGFF5j300EOKi4vTpEmTlJycrCeeeEJPPPFEkXbBwcFauHCh2rZt68ryKwxBCAAAE4iKitLWrVu1Y8cOxcXFyWazKSsrSyEhIWrZsqW6d++uUaNGqV69eg77mDBhgnr37q358+dry5YtOnnypDIyMhQcHKxmzZrprrvu0ujRo9WgQQM3rln5EIQAADCBAQMGaMCAAeXuJzIyUnPmzHFBRd6Bc4QAAIBpEYQAAIBpEYQAAIBpEYQAAIBpEYQAAIBpEYQAAIBpEYQAAIBpEYQAAIBpEYQAAIBpEYQAAIBp8YgNAKhk8mzJni6hzBpPrePpEsos39MFwC3YIwQAAEyLIAQAAEyLIAQAAEyLIAQAAEyLIAQAAEyLIAQAAEyLIAQAAEyLIAQAAEyLIAQAAEyLIAQAAEyLIAQAAEyLIAQAAEyLIAQAAEyLIAQAAEyLIAQAAEyLIAQAAEyLIAQAAEyLIAQAAEyLIAQAAEyLIAQAAEyLIAQAAEyLIAQAAEyLIAQAAEyLIAQAAEyLIAQAAEyLIAQAAEyLIAQAAEyLIAQAAEyLIAQAAEyLIAQAAEyLIAQAAEyLIAQAAEyLIAQAAEyLIAQAAEyLIAQAAEyLIAQAAEyLIAQAAEyLIAQAAEyLIAQAAEyLIAQAAEyLIAQAAEyLIAQAAEyLIAQAAEyLIAQAAEzL19MFAACuffk/x3i6hDLzqVvH0yWUTYJVyvd0EZUPe4QAAIBpEYQAAIBpEYQAAIBpEYQAAIBpEYQAAIBpEYQAAIBpEYQAAIBpEYQAAIBpEYQAAIBpEYQAAIBpEYQAAIBpEYQAAIBpEYQAADCpbdu2adSoUWrWrJmCgoJUo0YNRUREaPDgwfrggw9KXHbJkiXq0aOH6tatq4CAADVt2lSPP/64Dh8+7KbqXcNiGIbhaGaDBg105swZ+auqulh6u7MuAAA8qrI9fX5zwiJl5V9U/fr1FRcXV2LbrKws/fWvf9WiRYtKbFdcRMjNzdWgQYO0fPnyYpcJCAjQxx9/rCFDhpS+eA9ijxAAACaSl5engQMHatGiRbJYLHrkkUe0efNmxcfHKyEhQT/88INefvll/eEPfyh2+aefftoegoYPH679+/crISFBa9asUUREhDIzMzV8+HD98MMP7lwtp7FHCACAYlyre4RmzpypCRMmyGKxaPHixRo8eHCpxzh8+LBat26t/Px8DR8+XAsXLiw0PyEhQZGRkUpKStKf/vQnbdu2zdnVcRv2CAEAYBIpKSmaMmWKJGnkyJFlCkGSNG/ePOXn58vX11fTp08vMr9OnTp67rnnJEn//e9/tXfv3vKWXOEIQgAAmMSnn36qjIwMSdJTTz1V5uVXr14tSerSpYvq1atXbJtBgwbZp1etWuVEle5FEAIAwCSio6MlSeHh4YqMjLS/n5+fr7y8vBKXtdlsOnXqlCSpU6dODts1btzYHpL27NlT3pIrHEEIAACT2LVrlySpVatWMgxD8+fPV7t27RQQECA/Pz81bNhQo0aN0tGjR4ssGxMTY5++/vrrSxynadOmRZbxVgQhAABM4NKlS0pKSpIkVa9eXQMGDNDo0aP1008/KScnR4ZhKC4uTgsWLNBNN92kpUuXFlq+YFlJqlu3boljFcy/chlv5evpAgAAQOltTfq82Pez8zNKXO7ChQv26W+++UbZ2dnq3Lmz3njjDbVv314XL17UypUr9dxzz+n8+fN6+OGH1bx5c910002SpIsXL9qXDwgIKHGsqlWrSpLS09NLtU6exB4hAABMID8/3z6dnZ2ttm3b6ttvv9Vtt92mgIAA1axZU48++qjWrFkjq9WqrKwsTZ48udi+LBZLiWNdbb43YY8QAACVSOdaxd+xueA+Qo5Uq1at0H9PmjRJ/v7+Rdp16tRJvXr10jfffKN169YpMzNTAQEBCgoKsre5dOlSiTUWzP/9mN6IPUIAAJhAtWrVCgWfLl26OGzbtWtXSZcfxXHs2DFJUq1atezzExISShzr3LlzkqSaNWs6Xa+7EIQAADABq9WqFi1a2P87NDTUYdsr56WmpkpSoWWPHz9e4lgnT56UJEVERDhVqzsRhAAAMIlbbrnFPm2z2Ry2u3JeSEiIpMt7hBo3bixJJT5H7PTp0zp79qwkqX379uUp1y0IQgAAmMSAAQPs01u2bHHYbvPmzZKkoKAgNWvWzP5+nz59JEnfffed4uPji132yy+/tE/37du3POW6BUEIAACTuPvuu+2HuF577TX74zautGnTJq1bt06SdP/998vPz88+729/+5usVqtyc3M1adKkIssmJiZq5syZki6fdH3zzTdXxGq4FEEIAACT8PX11bvvvisfHx8dOnRI3bp10/r162Wz2XT69GnNmTNH/fr1k2EYCgsL0yuvvFJo+VatWmnMmDGSpKioKI0cOVIHDx5UYmKi1q5dq65duyohIUF+fn6aNWuWJ1axzCyGYRiOZjZo0EBnzpyRv6qqi6W3O+sCAMCjfOrW8XQJZVJw+Xz9+vUVFxdXYtuoqCj97W9/U1ZWVrHz69atq5UrV6pjx45F5uXm5mrQoEFavnx5scsGBATo448/1pAhxV/m723YIwQAgMmMGDFCP/30k0aPHq3rr79eAQEBCg4OVrt27TRlyhQdOnSo2BAkXd6rtGzZMn3++efq3r27ateuLX9/fzVp0kSjRo3Snj17Kk0IktgjBABAsa7lPUL4H/YIAQAA0yIIAQAA0yIIAQAA0yIIAQAA0yIIAQAA0yIIAQAA0yIIAQAA0yIIAQAA0yIIAQAA0yIIAQAA0yrxERtVqlRRTk6OJMlfVd1WFAAAHmetXPsKsvIzJBny8/NTdna2p8upNEoMQj4+PsrPz3dnPQAAoBysVqvy8vI8XUal4VvSzICAAGVmZsrHx0d16lSuh88BAGAmCQkJysvLU0BAgKdLqVRK3CMEAABwLatcB0ABAABciCAEAABMiyAEAABMiyAEAABMiyAEAABM6/8Bj515zi65zYAAAAAASUVORK5CYII=",
      "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.94, vmax=0.974)\n",
    "# plt.imshow(cos_sim)\n",
    "plt.xticks(np.arange(0,11,2), np.arange(50,61,2))\n",
    "plt.yticks(np.arange(0,11,2), np.arange(50,61,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('single anchor: 2')\n",
    "plt.ylabel('single anchor: 1')\n",
    "# row, col = 6, 0  # 色块的行列位置\n",
    "for [row, col] in [[0, 4], [1,5], [2,6], [3, 7], [4, 8], [5,9], [6,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",
    "\n",
    "# plt.colorbar()\n",
    "\n",
    "plt.savefig('./LLM/plot_for_neurips/pic/cos_sim_1_2_condense.png', dpi=300)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 90,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 512x384 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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pMmLlWAiIiIiMjmsBBMRERHJQjDgmGCONVaHlWAiIiIiMjmsBBMRERHJxGDzBJNavPNEREREZHJYCSYiIiKSCecJlg8rwURERERkclgJJiIiIpIB5wmWF5PgyqhrDvzcRO4oNJa6znhiBQDHyJNyh6A1wcpK7hC0Jubmyh0CERFRlWMSTERERCQTjgmWD8cEExEREZHJYSWYiIiISCasBMuHlWAiIiIiMjmsBBMRERHJhJVg+bASTEREREQmh5VgIiIiIpmwEiwfVoKJiIiIyOTovRL8+++/AwA6dOgAW1tbfXdPREREVCPwjXHy0nsS3LNnT5iZmeH8+fNo06aNvrsnIiIiIqo0g4wJFkV+/yAiIiJSSRQMNyaYY43VUpkEz507V+eOv//+ezRs2LDMtlmzZuncHxERERGRvqhMgsPCwiAI2n+TEEURq1evLredSTARERHR/3B2CPloNBxCl+ENzx+jSzJNREREVJMxCZaPyiTY0tIS+fn5eOGFF7B06VJ4e3ur7EwURTRv3hyCIGDv3r3w8vLSa7BERERERPqgMgn+66+/MHbsWBw/fhwDBw7ElClTMHPmTFhbW6vt2NXVFe7u7noLlIiIiKgmEWG4SjCnKFBP5csyvLy88Mcff2DlypWwtbXFwoUL0bp1a+zfv7+q4iMiIiIi0juN3hg3btw4XLlyBf3798ft27fRt29fDB06FAkJCYaOj4iIiKjGEkXBIAupp/Frkxs1aoSoqCj88ssvaNiwIX766Sd4eXlh1apVhoyPiIiIiEjvNE6CSwQFBeHq1asYM2YMMjIyEBISAl9fX/z999+GiI+IiIioxiqCYJCF1NM6CQYAR0dHrF69GrGxsXjppZdw6tQpdOjQAZMnT9Z3fEREREREeqdTElyiW7duuHjxImbMmAFBELBkyRI9hUVERERU8xX9/1cn63sh9SqVBAPFcwl/8cUXOHfuHHr06AF3d3e4ubnB0tJSH/EREREREemdRm+M00Tr1q3x22+/6as7IiIiohqPMznIp9KVYCIiIiIiY6O3SjARERERaYfjd+XDSjARERERmRxWgomIiIhkIMJwb3cTOVewWqwEExEREZHJYSWYiIiISA6iAccEi4bptiZhJZiIiIiITA4rwUREREQyEVmxlQ0rwURERERkclgJJiIiIpJJEWdxkA0rwURERERkcnSq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",
      "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.94, vmax=0.974)\n",
    "# plt.imshow(cos_sim)\n",
    "plt.xticks(np.arange(0,11,2), np.arange(50,61,2))\n",
    "plt.yticks(np.arange(0,11,2), np.arange(50,61,2))\n",
    "\n",
    "plt.xlabel('single anchor: 3')\n",
    "plt.ylabel('single anchor: 4')\n",
    "# row, col = 6, 0  # 色块的行列位置\n",
    "for [row, col] in [[7, 0], [8,1], [9,2], [10, 3]]:\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",
    "cbar.set_ticks([0.94, 0.95, 0.96, 0.97])\n",
    "\n",
    "plt.savefig('./LLM/plot_for_neurips/pic/cos_sim_4_3_condense.png', dpi=300)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 80,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[0.946172  , 0.93267596, 0.9064208 , 0.913769  , 0.89988387,\n",
       "        0.873283  , 0.83352625, 0.85533243, 0.82795846, 0.7889339 ,\n",
       "        0.80065227],\n",
       "       [0.94486755, 0.9441116 , 0.93064666, 0.9117255 , 0.910692  ,\n",
       "        0.89715075, 0.87020886, 0.8654206 , 0.8512465 , 0.8252249 ,\n",
       "        0.8099656 ],\n",
       "       [0.9303909 , 0.94280887, 0.9427865 , 0.8965175 , 0.9087899 ,\n",
       "        0.9089583 , 0.8956826 , 0.86296004, 0.8626714 , 0.850487  ,\n",
       "        0.80706704],\n",
       "       [0.9638045 , 0.9497148 , 0.9223528 , 0.94077486, 0.9263076 ,\n",
       "        0.898543  , 0.85707295, 0.89112914, 0.8626518 , 0.8217019 ,\n",
       "        0.8452611 ],\n",
       "       [0.9637076 , 0.9629495 , 0.94896424, 0.94016457, 0.93918693,\n",
       "        0.92506385, 0.8969712 , 0.9034969 , 0.8888624 , 0.86144656,\n",
       "        0.85707957],\n",
       "       [0.9496421 , 0.9623587 , 0.9620988 , 0.9253803 , 0.93799746,\n",
       "        0.937884  , 0.92373216, 0.9017629 , 0.90129375, 0.8880111 ,\n",
       "        0.85489494],\n",
       "       [0.92191654, 0.9483019 , 0.96216637, 0.89710844, 0.9235371 ,\n",
       "        0.9378251 , 0.9382318 , 0.8870938 , 0.90122205, 0.90265644,\n",
       "        0.8402979 ],\n",
       "       [0.9738073 , 0.9729943 , 0.9585248 , 0.9605167 , 0.9594945 ,\n",
       "        0.9448415 , 0.9157411 , 0.93417275, 0.9190717 , 0.89042914,\n",
       "        0.8976046 ],\n",
       "       [0.95995796, 0.97327983, 0.97321   , 0.9462908 , 0.9595854 ,\n",
       "        0.9596053 , 0.94511294, 0.93405306, 0.9338702 , 0.9199738 ,\n",
       "        0.8974152 ],\n",
       "       [0.9315926 , 0.9588225 , 0.97310895, 0.91723406, 0.94454706,\n",
       "        0.9592244 , 0.9595258 , 0.9186749 , 0.9332924 , 0.9344001 ,\n",
       "        0.8819413 ],\n",
       "       [0.9747682 , 0.9740069 , 0.9592962 , 0.9723776 , 0.9714672 ,\n",
       "        0.9565098 , 0.92677563, 0.957275  , 0.9420076 , 0.9124494 ,\n",
       "        0.9314635 ]], dtype=float32)"
      ]
     },
     "execution_count": 80,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "cos_sim"
   ]
  }
 ],
 "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
}
