{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "64464f37-25a4-47ad-9aa7-e212e58eebc6",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import pandas as pd\n",
    "import transformers\n",
    "import torch\n",
    "import numpy as np\n",
    "from Code.utinity import *\n",
    "from Code.models import *\n",
    "\n",
    "from tqdm import tqdm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "800f3c6d-dc4b-42bd-92b6-ea72cbf2b9ce",
   "metadata": {},
   "outputs": [],
   "source": [
    "class LLM_u(LLM):\n",
    "    def get_attention_matrix(self,outputs):\n",
    "        A = 0\n",
    "        for layer in range(len(outputs.attentions)):\n",
    "            X = outputs.attentions[layer][0].to(torch.float32).cpu().detach().numpy()\n",
    "            for i in range(len(X)):\n",
    "                Ai = (X[i] + X[i].T)/2\n",
    "               \n",
    "                A = (A+Ai)/2 + abs(A-Ai)/2\n",
    "       \n",
    "        A = np.triu(A)\n",
    "        return A"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5dc43ba7-3c39-49d9-b89c-2d6f15ae6c1e",
   "metadata": {},
   "source": [
    "## Settings\n",
    "\n",
    "Using Llama2 as the base model, compare the existing algorithm (baseline) with our designed algorithm (ours)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dffbfd63-071d-45af-8fef-95a52665477a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "bert 调用成功!\n"
     ]
    }
   ],
   "source": [
    "model_name = 'bert'\n",
    "llm = LLM_u(model_name,load_model=True)\n",
    "# llm = LLM_u('gpt2',load_model=True)\n",
    "llm.model_name = model_name + 'uu_test'\n",
    "solver_baseline = Solver_Baseline(llm)\n",
    "solver_ours_v = Solver_Ours(llm, repeat=1, shift=False, attention=True)\n",
    "solver_ours_vv = Solver_Ours(llm, repeat=2, shift=False, attention=True)\n",
    "solver_ours_vvv = Solver_Ours(llm, repeat=3, shift=False, attention=True)\n",
    "solver_ours_vvvv = Solver_Ours(llm, repeat=4, shift=False, attention=True)\n",
    "solver_ours_vvvvv = Solver_Ours(llm, repeat=5, shift=False, attention=True)\n",
    "solvers = [solver_baseline,solver_ours_v,solver_ours_vv,solver_ours_vvv,solver_ours_vvvv,solver_ours_vvvvv]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "11b5a9fa-a236-48b7-b20b-f7b2313d8cf4",
   "metadata": {},
   "source": [
    "## Val"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "83619f50-4c36-46b1-9edd-fb45ffba5e03",
   "metadata": {},
   "outputs": [],
   "source": [
    "results = {}\n",
    "accuracy = {}\n",
    "# def RunEval(problem,use_temp=True):\n",
    "def RunEval(problem,use_temp=True):\n",
    "    results[problem.name] = []\n",
    "    accuracy[problem.name] = []\n",
    "    for i,solver in enumerate(solvers):\n",
    "        # if i == 3:\n",
    "        #     use_temp = False\n",
    "        evaluation = Evaluation(problem,solver,later=False,use_temp=use_temp)\n",
    "        df1,df2 = evaluation.save(filename='result/'+problem.name+'_'+solver.name+'.xlsx')\n",
    "        results[problem.name].append(df1)\n",
    "        accuracy[problem.name].append(df2)\n",
    "    # accuracy[problem.name] = pd.concat([df2,df4],axis=1).T # 添加结果\n",
    "    return pd.concat(accuracy[problem.name],axis=1).T"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e8adb696-771c-45e2-bb89-6ac87d510876",
   "metadata": {},
   "source": [
    "### Dataset 1: SLPWC"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "037d3ae7-83b0-4faa-a37a-a6a993dac4f7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "利用 bertuu_test_baseline 计算目标词的向量嵌入：\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "91a8fba86292448e90a95344703d04ed",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/300 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "没有找到词: emo “emo”是一种与朋克相似的摇滚乐，最初从HardcorePunk(硬核朋克)中派生出来，但包含更为复杂的改编曲，歌词更多触及情感主题。\n",
      "没有找到词: emo 以后不在朋友圈装emo了，其实我这个长相，根本没有那么多感情问题\n",
      "没有找到词: emo 明天开学要分班，狠狠emo了。\n",
      "没有找到词: emo 我emo了，有一瞬间我想过死亡。\n",
      "保存文件： Temp/temp_embeddings_SLPWC_bertuu_test_baseline.dat\n"
     ]
    },
    {
     "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>distance_shift</th>\n",
       "      <th>cos_similarity_shift</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>bertuu_test_baseline</th>\n",
       "      <td>0.843333</td>\n",
       "      <td>0.853333</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                      distance_shift  cos_similarity_shift\n",
       "bertuu_test_baseline        0.843333              0.853333"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "result = RunEval(problem=Problem(\"Data/SLPWC_v1.csv\",name='SLPWC'))\n",
    "result"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "07fe38e8",
   "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>model</th>\n",
       "      <th>cos_similarity_shift</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>bertuu_test_baseline</th>\n",
       "      <td>0.843333</td>\n",
       "      <td>0.853333</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                         model  cos_similarity_shift\n",
       "bertuu_test_baseline  0.843333              0.853333"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# columns = ['model', 'distance_shift', 'cos_similarity_shift']\n",
    "result.insert(0, 'model', result.iloc[:, 0])\n",
    "result.drop(result.columns[1], axis=1, inplace=True) \n",
    "\n",
    "result"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "3653a30f-35e3-4aff-b541-143ff33592af",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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Kfroo4+0bNky6/DxcuXKZXp/pvwClCtXLuu0b7/9Vs2aNVPlypU1atQoOTk5WX/J3LJlS6qe8bZt2yokJEQTJkzQ999/r3feeUcXLlywKUDGjRunkSNHqm3btnr22Wd15swZTZs2TXXr1tWPP/6onDlzasSIEbp06ZL+/PNPTZ48WZLk7e1tN+/M7tf9+/erTp068vX11SuvvCIXFxe9//77ql+/vjZt2qRq1arZxPfr10+5cuXSqFGjFB0drSlTpqhv375atGiRpOSenSZNmsjf319Dhw5Vzpw5FR0draVLl942l4y8vykuXLigpk2b6oknnlDbtm21ZMkSDRkyRGXLllWzZs1uu660eHt7q3Xr1vrwww914MABlS5d2m5cr169tGTJEvXt21ehoaE6d+6ctm7dqoMHD6pSpUrpvmcxMTH64IMP1L59ez333HO6fPmyPvzwQ4WFhWnnzp2qUKGCzboWLFigy5cv6/nnn5fFYtGbb76pJ554Qr///rt1n/z888+qU6eOXFxc1LNnT4WEhOjo0aP68ssvNW7cOEnS33//rerVq8tisahv377y9/fX6tWr1aNHD8XExNx2WOmMGTNUunRpPf7448qRI4e+/PJL9e7dW0lJSerTp49N7JEjR9SmTRv16NFDXbp00Zw5c9S1a1dVrlzZuk9PnTqlBg0a6MaNGxo6dKi8vLw0a9YseXh43PZ9iouL0/r161W3bl099NBDt403xujxxx/Xhg0b1KNHD1WoUEHffPONXn75ZZ04ccL6Hu3fv1+PPfaYypUrp9dff11ubm46cuRIqj+u2ZOYmKiwsDBVq1ZN//vf/7Ru3Tq9/fbbKlq0qM3oieeff16RkZHq1q2bXnzxRUVFRendd9/Vjz/+mOo4v1VwcLDWr1+vP//8U4GBgbfNyZ527dqpVKlSeuONN7Ry5UqNHTtWuXPn1vvvv69HH31UEydO1Pz58zV48GBVrVpVdevWzVT7mTlODh8+rPbt2+v555/Xc889Z7dQrlu3rl588UW98847Gj58uEqVKiVJKlWqlDp16qSPPvpI33zzjR577DHrMqdOndK3335rM7T7Vvny5ZOHh4e+/PJL9evXT7lz577ttr3xxhtycnLS4MGDdenSJb355pvq2LFjmveGKFWqlD7++GMNHDhQgYGB1stbypYtq+vXr+vTTz/V5MmT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+otneHi4ypYtq44dO2r37t1ycnKybttbb72V6hrcFGldd53i1kIxKSnJepMbe+/T7drLDrc7niwWi5YsWaLvv/9eX375pb755ht1795db7/9tr7//vss26asPK5vlXIn7PQeRde2bVvVqVNHy5Yt05o1a/TWW29p4sSJWrp06W2vMf/kk0/UtWtXtWrVSi+//LLy5csnZ2dnTZgwIdXN/KSs2daU4/eZZ55Rly5d7Makdy+Eo0ePqmHDhnr44Yc1adIkBQUFydXVVatWrdLkyZNTffYd+f5Iye9Njhw59Msvv2RJeyk8PDy0efNmbdiwQStXrtTXX3+tRYsW6dFHH9WaNWvS3C4p7W2+WVJSkvLly6f58+fbnX9r4Z4eT09P1alTR3Xq1FHevHkVERGh1atXp/n+ppdnVr1fmT1OMnI9/+2EhoaqcuXK+uSTT9S5c2d98skncnV1tRnplRG+vr5q3LixGjduLBcXF82bN087duxQvXr1rDGOPq6luzsGa9eurXHjxunatWvasmWLRowYoZw5c6pMmTLasmWL9Rrnuy28s3o/3O13Y1YcR7d6/PHH5ebmpi5duig+Pj7Tx9PdyMrzBJAeCm8gG/32229q0KCB9XVsbKxOnjyp5s2bS0q+++m5c+e0dOlSmxvuREVF2bRTtGhRSckFTKNGjdJcX2aGnacM8Tp8+LDNsOjr168rKioq3fVklre3t0aNGqVu3brps88+09NPP23dJl9f3wyv67fffrPp0Tly5IiSkpKsd4gtWrSojDEqXLiwSpQokW5bmdlXGY319/eXp6enDh8+nGreoUOH5OTkpKCgoAyv92bVq1dX9erVNW7cOC1YsEAdO3bUwoULbYa53uzffH/TExsbq2XLlikoKMjaG5qWgIAA9e7dW71799bp06dVqVIljRs3zlp4p/U+LFmyREWKFNHSpUttYtK7EVR6UvZXeo/O8vf3l4+PjxITE+9oX3755ZeKj4/XihUrbHq77mbIY3BwsHUkyc3sHY+38vT01KOPPqpvv/1Wf/zxx22P0+DgYK1bt06XL1+26fVOuTzm5iGkTk5OatiwoRo2bKhJkyZp/PjxGjFihDZs2HDXx2HRokW1bt061apVK0uLhSpVqkhKHs6anRxxnEi3P6d17txZgwYN0smTJ7VgwQK1aNHC5vKMzKpSpYrmzZvn0P2Z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0I0bN9Lc/hUrVmj48OFq3ry5QkJCVLlyZfXr10/du3e3iYuLi0szr5uHmqf8/9y5c+revbssFosiIyMVERGhn376yTrC4OZ9CzgChTcAAAAeaMZIV65k7CcmRnrxxeRl7LUjJfeEx8RkrD177WTWo48+qvLly2tpGhX/O++8oxUrVuizzz7T4cOHNX/+fGuBvWvXLknS3LlzdfLkSevr2NhYNW/eXOvXr9ePP/6opk2bKjw8XMePH7dp++2331aVKlX0448/qnfv3nrhhRd0+PBhaxv16tXTiRMntGLFCv3000965ZVXrMPit2zZos6dO6t///46cOCA3n//fUVGRmrcuHFpbmuBAgW0atUqXb58Od19kl5eN0sZdu7r66spU6bo5MmTateunV566SWVLl1aJ0+etE4DHImh5gAAAHigxcVJ3t5Z05YxyT3hfn4Zi4+Nlby87n69Dz/8sH7++We7844fP67ixYurdu3aslgsCg4Ots7z9/eXJOXMmdNm+HX58uVVvnx56+sxY8Zo2bJlWrFihfr27Wud3rx5c/Xu3VuSNGTIEE2ePFkbNmxQyZIltWDBAp05c0a7du1S7ty5JUnFihWzLhsREaGhQ4eqS5cukqQiRYpozJgxeuWVVzRq1Ci72zJr1ix17NhRefLkUfny5VW7dm21adNGtWrVsolLL6+bpQw7t1gs8vPzs+4Db29v5ciR44Edso97Dz3eAAAAwD3OGJPm84S7du2qvXv3qmTJknrxxRe1Zs2a27YXGxurwYMHq1SpUsqZM6e8vb118ODBVD3e5cqVs/7fYrGoQIECOn36tCRp7969qlixorXovtVPP/2k119/Xd7e3taf5557TidPnlRcXJzdZerWravff/9d69evV5s2bbR//37VqVNHY8aMyXBewL2IHm8AAAA80Dw9k3ueM2LzZql589vHrVol1a2bsXVnhYMHD6pw4cJ251WqVElRUVFavXq11q1bp7Zt26pRo0ZasmRJmu0NHjxYa9eu1f/+9z8VK1ZMHh4eatOmja5fv24T5+LiYvPaYrFYh5J7eHikm3NsbKwiIiL0hJ270bm7u6e5nIuLi+rUqaM6depoyJAhGjt2rF5//XUNGTJErq6ut80LuBdReAMAAOCBZrFkfLh3kybJdy8/ccL+9dkWS/L8Jk0kZ+eszTMt3377rX755RcN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AwAAAADgQBTeAAAAAAA4EIU3AAAAAKuQkBBNmTLF+tpiseiLL774V9Zdt25dLViw4F9ZV4quXbveE88Pj4yMVM6cOe+6nZvfr+joaFksFu3du/eu2731uPi3ZGQb7O27WbNmKSgoSE5OTmnmfeDAAQUGBurKlStZl3AaKLwBAACAe0DXrl1lsVisP3ny5FHTpk31888/Z2teJ0+eVLNmzRy+nhUrVujvv//W008/bTP9xx9/1FNPPaX8+fPL3d1dxYsX13PPPadff/01S9Y7depURUZGZklb6dm0aZMeffRR5c6dW56enipevLi6dOmi69evS5LatWuXJdvkqPdr165d6tmzp/V1Vv1BJioqSh06dFDBggXl7u6uwMBAtWzZUocOHcpwG7fuu5iYGPXt21dDhgzRiRMn1LNnT9WvX18DBgywWS40NFTVq1fXpEmT7no7bofCGwAAALhHNG3aVCdPntTJkye1fv165ciRQ4899li25lSgQAG5ubk5fD3vvPOOunXrJienf0qUr776StWrV1d8fLzmz5+vgwcP6pNPPpGfn59GjhyZJev18/PLkp7m9Bw4cEBNmzZVlSpVtHnzZv3yyy+aNm2aXF1dlZiYKEny8PBQvnz57npdWf1+pfxhwN/fX56enlnWriQlJCSocePGunTpkpYuXarDhw9r0aJFKlu2rC5evJjhdm7dd8ePH1dCQoJatGihgICAdPPu1q2bZsyYoRs3btzNptyeQSqXLl0yksylS5eyOxUAAO4J169fN1988YW5fv16dqcCpOvq1avmwIED5urVq9mdSqZ16dLFtGzZ0mbali1bjCRz+vRp67RXXnnFFC9e3Hh4eJjChQubV1991eazuXfvXlO/fn3j7e1tfHx8TKVKlcyuXbts2qxdu7Zxd3c3gYGBpl+/fiY2NtY6Pzg42EyePNn6WpJZtmyZMcaYqKgoI8l8/vnnpn79+sbDw8OUK1fObN++PVXe6a3jVqdPnzYWi8Xs27fPOu3KlSsmb968plWrVnaXuXDhgvX/GzduNFWrVjWurq6mQIECZsiQISYhIcE6f/HixaZMmTLG3d3d5M6d2zRs2NCaz637vV69eqZfv37m5ZdfNrly5TL58+c3o0aNSrXuHj16mLx58xofHx/ToEEDs3fv3jS3b/LkySYkJCTN+cYYM3fuXOPn52d9PWrU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6urSp0+fjB49Ohs2bDjm+sWLF2fYsGGprq5ObW1t5syZk4MHD76jYwIAAEARSh7eK1asSENDQxobG7N58+aMGDEi48ePz0svvXTU9Q8++GBuvPHGNDY2Ztu2bbnvvvuyYsWKzJ0794SPCQAAAEUpeXgvWrQo1157bWbMmJEPfOADueeee9K3b9/cf//9R12/fv36XH755bn66qtTV1eXq666Kl/60pe6ndF+u8cEAACAolSW8s0PHTqUTZs25aabburaVl5envr6+jzxxBNH3ecjH/lIfvazn2XDhg0ZNWpUnn/++TzyyCOZOnXqCR+zra0tbW1tXa9bWlqSJO3t7Wlvb3/HnxMATnZv/B76XQSAf3s7v4klDe99+/bl8OHDqamp6ba9pqYmf/vb3466z9VXX519+/blox/9aDo7O/P666/na1/7Wtel5idyzKamptx6661HbH/00UfTt2/fE/loAPA/afXq1aUeAQB6hAMHDhz32pKG94lYu3Ztbrvtttx1110ZPXp0/v73v2f27Nn53ve+l3nz5p3QMW+66aY0NDR0vW5paUltbW2uuuqqnHrqqf+t0QHgpNXe3p7Vq1dn3Lhx6dWrV6nHAYCSe+NK6eNR0vAeNGhQKioqsnfv3m7b9+7dmyFDhhx1n3nz5mXq1Kn56le/miT50Ic+lNbW1lx33XW5+eabT+iYVVVVqaqqOmJ7r169/OcCAP6D30YA+Le383tY0oer9e7dO5dcckmam5u7tnV0dKS5uTljxow56j4HDhxIeXn3sSsqKpIknZ2dJ3RMAAAAKErJLzVvaGjItGnTcumll2bUqFFZvHhxWltbM2PGjCTJV77ylZx11llpampKkkycODGLFi3KRRdd1HWp+bx58zJx4sSuAH+rYwIAAMC7peThPWXKlLz88suZP39+9uzZk5EjR2bVqlVdD0fbtWtXtzPct9xyS8rKynLLLbfkxRdfzODBgzNx4sR8//vfP+5jAgAAwLulrLOzs7PUQ/Q0LS0tGTBgQF599VUPVwOA/Pvhao888kg+9alPuccbAPL2urGk93gDAADA/zrhDQAAAAUS3gAAAFAg4Q0AAAAFEt4AAABQIOENAAAABRLeAAAAUCDhDQAAAAUS3gAAAFCgylIP0BN1dnYmSVpaWko8CQD0DO3t7Tlw4EBaWlrSq1evUo8DACX3Ri++0Y/HIryPYv/+/UmS2traEk8CAABAT7Z///4MGDDgmGvKOo8nz/+f6ejoyD//+c/0798/ZWVlpR4HAEqupaUltbW1+cc//pFTTz211OMAQMl1dnZm//79ec973pPy8mPfxS28AYC31NLSkgEDBuTVV18V3gDwNnm4GgAAABRIeAMAAECBhDcA8JaqqqrS2NiYqqqqUo8CACcd93gDAABAgZzxBgAAgAIJbwAAACiQ8AYAAIACCW8A4C3deeedqaurS58+fTJ69Ohs2LCh1CMBwElDeAMAx7RixYo0NDSksbExmzdvzogRIzJ+/Pi89NJLpR4NAE4KnmoOABzT6NGjc9lll2XJkiVJko6OjtTW1uaGG27IjTfeWOLpAKDnc8YbAHhThw4dyqZNm1JfX9+1rby8PPX19XniiSdKOBkAnDyENwDwpvbt25fDhw+npqam2/aamprs2bOnRFMBwMlFeAMAAECBhDcA8KYGDRqUioqK7N27t9v2vXv3ZsiQISWaCgBOLsIbAHhTvXv3ziWXXJLm5uaubR0dHWlubs6YMWNKOBkAnDwqSz0AANCzNTQ0ZNq0abn00kszatSoLF68OK2trZkxY0apRwOAk4LwBgCOacqUKXn55Zczf/787NmzJyNHjsyqVauOeOAaAHB0/o43AAAAFMg93gAAAFAg4Q0AAAAFEt4AAABQIOENAAAABRLeAAAAUCDhDQAAAAUS3gAAAFAg4Q0AAAAFEt4AwHFbunRpBg4c+JbrysrK8pvf/KbweQDgZCC8AaCHmT59esrKylJWVpZevXrl3HPPzXe+850cPHjwXZ2jrq4uixcv7rZtypQp2b59e9frBQsWZOTIkUfsu3v37nzyk58seEIAODlUlnoAAOBIEyZMyAMPPJD29vZs2rQp06ZNS1lZWW6//faSzlVdXZ3q6uq3XDdkyJB3YRoAODk44w0APVBVVVWGDBmS2traTJo0KfX19Vm9enWSpKOjI01NTTn33HNTXV2dESNG5Fe/+lXXvmvXrk1ZWVkefvjhXHjhhenTp08+/OEPZ+vWrd3eY926dbniiitSXV2d2trazJo1K62trUmSj3/843nhhRcyZ86crrPvSfdLzZcuXZpbb701Tz75ZNeapUuXJjnyUvOnn346n/jEJ1JdXZ0zzjgj1113XV577bWuf58+fXomTZqUH/3oRznzzDNzxhln5Otf/3ra29u71tx1110ZOnRo+vTpk5qamnz+85//r33fAFAk4Q0APdzWrVuzfv369O7dO0nS1NSU5cuX55577skzzzyTOXPm5Mtf/nIef/zxbvt9+9vfzo9//ONs3LgxgwcPzsSJE7tCdseOHZkwYUImT56cp556KitWrMi6desyc+bMJMnKlStz9tlnZ+HChdm9e3d27959xFxTpkzJN7/5zQwfPrxrzZQpU45Y19ramvHjx+e0007Lxo0b88tf/jKPPfZY13u9Yc2aNdmxY0fWrFmTZcuWZenSpV0h/5e//CWzZs3KwoUL8+yzz2bVqlX52Mc+9o6/WwB4N7jUHAB6oIceeiinnHJKXn/99bS1taW8vDxLlixJW1tbbrvttjz22GMZM2ZMkuS8887LunXrcu+99+bKK6/sOkZjY2PGjRuXJFm2bFnOPvvs/PrXv84Xv/jFNDU15Zprrsk3vvGNJMnQoUNzxx135Morr8zdd9+d008/PRUVFenfv/+bXjZeXV2dU045JZWVlce8tPzBBx/MwYMHs3z58vTr1y9JsmTJkkycODG33357ampqkiSnnXZalixZkoqKirz//e/Ppz/96TQ3N+faa6/Nrl270q9fv3zmM59J//79c8455+Siiy56x98zALwbhDcA9EBjx47N3XffndbW1vzkJz9JZWVlJk+enGeeeSYHDhzoCuo3HDp06IgQfSPMk+T000/PsGHDsm3btiTJk08+maeeeio///nPu9Z0dnamo6MjO3fuzAUXXPBf+yzbtm3LiBEjuqI7SS6//PJ0dHTk2Wef7Qrv4cOHp6KiomvNmWeemaeffjpJMm7cuJxzzjk577zzMmHChEyYMCGf/exn07dv3//anABQFOENAD1Qv3798r73vS9Jcv/992fEiBG577778sEPfjBJ8vDDD+ess87qtk9VVdVxH/+1117L9ddfn1mzZh3xb+9973vfweQnrlevXt1el5WVpaOjI0nSv3//bN68OWvXrs2jjz6a+fPnZ8GCBdm4ceNx/XkzACgl4Q0APVx5eXnmzp2bhoaGbN++PVVVVdm1a1e3y8qP5s9//nNXRL/yyivZvn1715nsiy++OH/961+74v5oevfuncOHDx/zPY5nzQUXXJClS5emtbW166z3n/70p5SXl2fYsGHH3Pc/VVZWpr6+PvX19WlsbMzAgQPzhz/8IZ/73OeO+xgAUAoergYAJ4EvfOELqaioyL333ptvfetbmTNnTpYtW5YdO3Zk8+bN+elPf5ply5Z122fhwoVpbm7O1q1bM3369AwaNCiTJk1Kknz3u9/N+vXrM3PmzGzZsiXPPfdcfvvb33Z74FldXV3++Mc/5sUXX8y+ffuOOlddXV127tyZLVu2ZN++fWlraztizTXXXJM+ffpk2rRp2bp1a9asWZMbbrghU6dO7brM/K089NBDueOOO7Jly5a88MILWb58eTo6Ot5WuANAqTjjDQAngcrKysycOTM//OEPs3PnzgwePDhNTU15/vnnM3DgwFx88cWZO3dut31+8IMfZPbs2XnuuecycuTI/O53v+t6MvqFF16Yxx9/PDfffHOuuOKKdHZ25vzzz+/2VPKFCxfm+uuvz/nnn5+2trZ0dnYeMdfkyZOzcuXKjB07Nv/617/ywAMPZPr06d3W9O3bN7///e8ze/bsXHbZZenbt28mT56cRYsWHffnHzhwYFauXJkFCxbk4MGDGTp0aH7xi19k+PDhb+NbBIDSKOs82q8oAHDSWrt2bcaOHZtXXnnF/c8A0AO41BwAAAAKJLwBAACgQC41BwAAgAI54w0AAAAFEt4AAABQIOENAAAABRLeAAAAUCDhDQAAAAUS3gAAAFAg4Q0AAAAFEt4AAABQIOENAAAABfo/QoCLmnoRg9gAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1000x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import pandas as pd\n",
    "\n",
    "# 创建 DataFrame\n",
    "data = {\n",
    "    \"model\": [solver.name for solver in solvers],\n",
    "    \"distance_shift\": [result.iloc[i, 0] for i in range(len(solvers))],\n",
    "    \"cos_similarity_shift\": [result.iloc[i, 1] for i in range(len(solvers))]\n",
    "}\n",
    "\n",
    "df = pd.DataFrame(data)\n",
    "\n",
    "# 添加重复次数列\n",
    "df['repetitions'] = df['model'].apply(lambda x: 0 if 'baseline' in x else x.count('v') - 1)\n",
    "\n",
    "# 绘制图表\n",
    "plt.figure(figsize=(10, 6))\n",
    "\n",
    "# 绘制欧氏距离和余弦相似度\n",
    "plt.plot(df['repetitions'][1:], df['distance_shift'][1:], marker='o', color='b', label='Distance Shift')\n",
    "plt.plot(df['repetitions'][1:], df['cos_similarity_shift'][1:], marker='o', color='g', label='Cosine Similarity Shift')\n",
    "\n",
    "# 添加 baseline 虚线\n",
    "baseline_distance = df[df['model'].str.contains('baseline')]['distance_shift'].values[0]\n",
    "baseline_cosine = df[df['model'].str.contains('baseline')]['cos_similarity_shift'].values[0]\n",
    "plt.axhline(y=baseline_distance, color='b', linestyle='--', label='Baseline (Distance Shift)')\n",
    "plt.axhline(y=baseline_cosine, color='g', linestyle='--', label='Baseline (Cosine Similarity Shift)')\n",
    "\n",
    "# 图表标题和标签'\n",
    "plt.title('Impact of Repetitions on Distance and Cosine Similarity Shifts with {} Model'.format(model_name))\n",
    "plt.xlabel('Repetitions')\n",
    "plt.ylabel('Shift Values')\n",
    "plt.xticks(df['repetitions'])\n",
    "plt.legend()\n",
    "plt.grid(True)\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "96992458-6533-4a2d-8877-03a571d53d78",
   "metadata": {},
   "source": [
    "## Data 2: WSD"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "d2b4ca51-56a4-4461-a14f-af96071ba0f3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "利用 bertuu_test_baseline 计算目标词的向量嵌入：\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a48a5108a8ef4ddb8911529278b1d900",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/862 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "没有找到词: 名称 \"君子疾没世而名不称焉。\n",
      "没有找到词: 那里 这儿瞧瞧,那儿看看,觉得什么都是新鲜的\n",
      "没有找到词: 龃龉 我们从未和邻居发生过一次龃龉\n",
      "没有找到词: 龃龉 原来放下一切的放松才是真正的愉快。没有罅隙，没有龃龉，没有试探，没有考量，没有阻碍，像是两个滑蛋从滑梯上滚落，毫无障碍的一生……，可惜，当我们面对这个世界的时候，能放下一切去爱的可能根本不存在\n",
      "没有找到词: 龃龉 圆凿而方枘兮，吾固知其龃龉而难入\n",
      "没有找到词: 龃龉 无论是对手足深情的正面展示，还是对手足龃龉的反面剖析，追求手足关系的敦睦乃灌注其中的本质内容\n",
      "没有找到词: 精简 精选人物\n",
      "没有找到词: 摄影 骋足则能追风摄景\n",
      "保存文件： Temp/temp_embeddings_WSD_bertuu_test_baseline.dat\n"
     ]
    },
    {
     "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>distance_shift</th>\n",
       "      <th>cos_similarity_shift</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>bertuu_test_baseline</th>\n",
       "      <td>0.610209</td>\n",
       "      <td>0.607889</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                      distance_shift  cos_similarity_shift\n",
       "bertuu_test_baseline        0.610209              0.607889"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "RunEval(problem=Problem('Data/WSD_v1.csv',name='WSD'))"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "llm",
   "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.0"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
