{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "metadata": {}
   },
   "outputs": [],
   "source": [
    "from datasets import load_dataset, Dataset\n",
    "from watermark_forspacy import Watermark\n",
    "import torch\n",
    "from transformers import AutoTokenizer\n",
    "from watermark import Detector\n",
    "from transformers import AutoTokenizer,AutoModelForCausalLM\n",
    "import torch\n",
    "dataset = load_dataset(\"json\", data_files=\"./LTW/c4_subset_500.jsonl\")\n",
    "dataset=dataset[\"train\"]\n",
    "print(dataset)\n",
    "gamma=0.25\n",
    "delta=3\n",
    "\n",
    "\n",
    "torch.cuda.set_device(4)\n",
    "device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "\n",
    "model= AutoModelForCausalLM.from_pretrained(\"./LTW/models/opt-6.7b\",torch_dtype=torch.float16).to(device)\n",
    "tokenizer=AutoTokenizer.from_pretrained(\"./LTW/models/opt-6.7b\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "metadata": {}
   },
   "outputs": [],
   "source": [
    "import json\n",
    "spacy_record_path=\"./LTW/eval/token_pos.json\"\n",
    "wm = Watermark(checkpoint_path=\"./LTW/ckpt/tmp/selective_network_epoch0_step2000.pth\",device=device,k=6,model=model,tokenizer=tokenizer, max_new_tokens= 225,min_new_tokens=175,record_spacy=True,spacy_record_path=spacy_record_path)\n",
    "for data in dataset:\n",
    "    text=data['text']    \n",
    "    input_text=text[:300]\n",
    "    output=wm.generate_watermark(input_text,gamma,delta)\n",
    "\n",
    "\n",
    " \n",
    "                "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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r7xSkjRz5kx17ty53OWysrL0xRdfaN26dfr777914sQJxcbGqmHDhrrkkkt00003qXHjxg7F9Pvvv1e5Dy1btpQkPfDAAxo1alSZ93r27KmMjAxJ0pVXXql33nmnynLPPvtsrVq1qspyfeHEiRPq3r278vPzJUnLli2rtO7mzp2rxx9//Izfx8TEqEaNGkpMTNR5552njh076pprrlFMTEyl5dvqtjSDwaAaNWronHPOUdeuXTVo0CA1bNjQuR3zsNLHTGkmk0m1a9dW69at1bdvX1133XUyGAz29yuqr/DwcMXFxSk5OVk9e/bUrbfeWmVd2Wzfvl3z5s3Txo0bdfDgQZ06dUq1atVSs2bNdNlll+nmm29WXFxcheuXjslgMGju3Llq3bp1hcvbPqMJEybohhtucCjG04Vq/ZUWERGh+Ph4tWzZUtddd5369++viIiIMsts3LhRQ4YMsf9/8uTJuuqqqyosy3Z+Ke/cU5qr9Tt48GBt2rRJF198sT766KMKt3967Kefn0ufuyXp8ccf15133lnhtmzlDhgwQC+//HKl5a5evVorV67Uli1bdOjQIZ06dUqxsbFKSkpS+/btdf311+uCCy6otB4c4ex5ubi4WMuWLdN3332nbdu26ciRI8rLy1PNmjXVuHFjdezYUX369FGLFi0q3MbOnTu1aNEibdy4UZmZmTKbzYqMjFT9+vXVrl07/etf/1KPHj3OOI5Kc/d66MnPrvTfxjfffKNGjRpVuB1HPPXUU/riiy9Uq1YtrV27ViaTyaH1rr76av3111+64oorNHXq1Ar/ZityeuwVHVcRERGqVauWWrZsqWuvvbbcv3mb0+v59O3Ex8erRYsWuuaaa3TjjTdW+pm7w2q1aunSpfrqq6+0fft2HTlyRGFhYapbt64SEhJ0/vnnq2PHjuratatiY2PL3UZBQYEWLlyoNWvW6LffftPRo0dVWFhoP4927txZffr0UVJSUqWxrFq1SkuXLtXWrVt16NAhWSwW1a1bV23bttWVV16p66+/XmFhYRWu/9hjj2nevHmSpISEBK1YsULR0dHlLlv6/FXesWk71zpyTvKlQLlHq+oaFAycrUtPXR+HDx+u1atX6+yzz9bChQsr/LuSpDFjxmjx4sWqV6+eFi1apDp16jixh/7lj2PVU9eIQOXM+dpkMumGG27Q7t27deGFF+rTTz+t9PxZXFysO+64Q1u3blXz5s01d+5cmUymMz6XsWPHavjw4ZXG+fzzz+vTTz+1/7+y7/CBpLJ8QOnvp0OGDNGTTz5Z4XZs16LS5wrb+cMVpa9DgXptqkp5900Gg0ExMTH2e9TzzjtPnTt3Vs+ePSv8263s3qk8tu+qnqp/XyKxGWTy8vI0efJkvfDCCy5vY/r06XrrrbeUm5srqeSPJC4uTmazWceOHdNvv/2mGTNmaMiQIfr3v/9d6Und07755hv9/PPPat++vc/KdNeiRYvsNyGS9OWXX2rs2LEOrVu7dm17/RYWFurIkSM6dOiQfvvtN82ZM0cvvPCC7r77bo0YMULh4ZX/ucbExNhvWoqLi3Xs2DFt375d27dv16xZs/TGG2+oR48eLu6lZ9WrV8/++uTJkzp48KAOHjyob7/9VvPmzdPkyZPLPUGXrq/c3FwdPXpUmzZt0qZNm/TJJ5/oww8/1Nlnn11huXl5eXruuec0f/58Wa1WSSVfiKOjo3X48GEdOnRIP/zwg9599109+eST6tevX5X7YrVa9dprr+n99993thpcFkr1VzqmnJwcHT58WIcPH9b69ev12Wefafr06YqPj69w/ZSUFF1xxRUePU+5Wr+eNHXqVN10002VfoGryp9//ql///vfSktLs/8uLCxMNWvW1MmTJ/Xrr7/q119/td9Av/HGG4qJiSmz/6UdPnxYUtlzTWm1a9d2OLatW7fq0Ucf1b59++y/i4iIUI0aNXT8+HFt2bJFW7Zs0bRp03T11VfrtddeK1Pn2dnZevbZZ7V48WL7sWgwGFSzZk3l5eVp79692rt3r+bPn69zzjlHkyZNsidvS/PG9dATn52n3HTTTfriiy90/PhxrVy5Ur169apynU2bNumvv/6yr3+60n+zFans/dLH16lTp3To0CEdOnRI69atc+hvXpJiY2MVFRVl/392drb93PH9999r9uzZmj59umrVqlXpdpxlNpt1//33l7nZDw8PV3R0tA4cOKD09HRt2bJFH3zwQYUPsr799ls988wzysrKsv/OZDKdcR59++23dcstt+i55547Yxvp6ekaO3astm3bZv9dVFSUwsLClJGRoYyMDC1btkxTpkxRSkpKpQ/ebA4dOqSZM2fqvvvuc7JWAlug3KOFAnfq0h0vvvii+vTpo4yMDL388ssaP358uct9/fXXWrx4saSSRFEwJTUl/xyr3rhGBApXztevvPKKbr31Vm3dulX//e9/Kz0f/ve//9XWrVsVERGhV155pcL7wrlz51aa2MzPz7cft6Fq1qxZGjp0qFMPa+Pj48u9Hy0sLNSJEyfsy5T3EDMQ7r88qXQ95OXlKSsrSwcPHtTPP/+sTz/9VLVq1dJDDz2k22+/vdLtnH7vVB7b+8FY/6F/FQ5BX375pYYNG6YmTZo4ve748ePtT0IuuOAC3X///fanVMXFxfr555/13nvv6bvvvtP06dP1999/KzU1VUaj70YtmDRpkj755BOfleeuOXPmSCp5svTRRx9p3rx5euihhxz6AjxnzpwyJ3mr1ao///zTnmjatWuXUlNTtXHjRr3//vuVJlPuuuuuMq0BsrOz9dVXX+nVV1/VqVOn9NBDD2nFihUVJi18af369fbXFotFe/fu1YQJE7R+/XqtWbNGr7/+uh599NEz1ju9vo4cOaKZM2dq6tSpSk9P17hx48o88SwtNzdXQ4cOtX8R7NOnj4YOHaq2bdvKYDAoNzdXa9as0VtvvaU9e/bokUce0dGjRzVs2LAq92fdunXasGGDunbt6mxVuCSU6u/0mNLT0/XGG2/oq6++Ulpamp5++mm99dZbFa6/d+9ezZs3z6M3167WrycdO3ZM77//vh588EGX1v/ll1909913y2w2KyYmRoMHD1avXr3UsmVLGQwGWSwW/fHHH1q5cqU++ugje+vbu+++W3fffXe527Q9fT/9XOOsVatW6cEHH1RBQYFq1aqlu+++W1dffbW9ZUpxcbG2b9+u5cuX69NPP9Xy5cuVl5dnP/+dOHFCAwcO1O7du2UwGNS7d2/dfvvtuuCCC+zLHDx4UGvWrNFHH32k33//XT///PMZiU1vXQ/d/ew86cILL1RycrL27NmjuXPnOvSlde7cuZJKbqQvv/zyM94//W/WWaX/viQpMzNTU6ZM0ezZs5WWlqbx48dr4sSJlW7jySefPCNpePDgQb3//vv68MMP9dtvvyklJcWth8DleeSRR7Rp0yaFhYVp6NChuvXWW3XOOefIaDSqqKhIe/bs0dq1a/XVV1+Vu/5nn32m559/XhaLRQ0aNNC9996rnj17qkGDBpJKvjBs27ZNX3/9tb744gt99dVXZyQ29+7dq8GDB+vIkSOKiorS3XffrQEDBthbdx45ckSLFy/W5MmT9eeff2rgwIF677331LFjxyr377333tOtt97q8YSwPwXKPVoocKcu3VG/fn099dRTGjdunL744gt7S/zSDh06pOeff16S1L9//0p7cgQqfxyr3rhGBApXztdt2rTRiBEjlJqaqtTUVPXo0UOtWrU6Y9u///67UlNTJUkjR45UmzZtyo3h7LPP1p9//qktW7booosuKneZlStX6sSJEzr77LPtPRhDTWFhod566y29+uqrDq9TUe+h0q27U1NTg6Jlq7tOv28qLi7Wnj179P333+vjjz/W/v379dxzz2nz5s2aNGlSmZ5lpZV371SRYKx/xtgMIg0aNFDLli1VVFSk119/3en158+fb/8S16dPH82aNUs9evSwX9zCwsLUsWNHvfvuuxo5cqSkkpPtlClTPLcTlbj88stlMBi0efNmffvttz4p012//fabduzYobi4OI0bN06NGjXSoUOHtHr1ape2ZzAY1LRpU912222aP3++PSm0adOmCp9QVyQ2Nla33XabvTtETk6O/WYkkBiNRjVv3lxTpkzRueeeK0n6/PPPVVRUVOW6devW1cMPP6wbb7xRkvTTTz/pzz//LHfZF154wZ6Ue/755zVp0iS1a9fOfvKPjo7WNddcoy+//FLdunWTJL366qvauHFjpTFcccUVkqTXXnvN3nLMl4K9/k6XlJSkSZMm2b+EL1++XIcOHSp3WVvdp6amlmnl4Enu1K+rbPv1wQcf2FtJOuPYsWMaNWqUzGazEhMTNXv2bI0ZM0atWrWyf15Go1HJyckaMWKEVq5cqVtvvbXCGyFP2rdvn8aNG6eCggIlJydrwYIFGj58eJnudmFhYWrXrp3Gjh2rb7755owuNP/+97+1e/duhYeH6/XXX1dKSoo6depUJqlQv3593XzzzVqwYIGeffZZRUZGltmGt66H7n523mBL+q9fv14HDx6sdNns7GwtW7ZMktSvXz+ftEJr2LChXnzxRXXp0kWStGTJEp06dcrp7dSvX19PPPGE/QHTypUrPRrnvn377PcmDz30kB599FE1btzYnugODw9Xq1atdO+992rBggVnJAh++uknvfjii7JYLOrUqZMWLVqkgQMH2pOaUkmr5Y4dO+qZZ57RsmXL1KFDhzLbyMvL04MPPqgjR44oNjZWH330kUaPHl2my3rdunU1ZMgQzZkzRw0bNlROTo4eeughHT16tMJ9a9u2rerVq6eTJ0/q3XffdbuuAkUg36MFG0/XpbP69u2rf/3rX5JKuk+bzeYy7z/99NM6fvy4zjrrrEq7vAYqfx6rgX6NcIU75+sRI0aoXbt2Kiws1COPPKKCgoIy2y4sLNSjjz6qwsJCnX/++RoxYkSFcQwYMEBSSaOkitjec3WoqkBnuy9atGiRdu7c6edoQkNYWJhatmypYcOG6auvvlLv3r0lSV999ZWmTZvm5+j8h8RmEDEajfYuCcuWLdMvv/zi8LoFBQV67bXXJElNmzbVSy+9VOkTwIceesj+5eC9996r9IbYU9q2batrrrlGUkn3UovF4vUy3WV7unrdddcpMjJS/fv3l1T5BcxRYWFheuyxx+xPQ+fMmVNh0qkyffv2tV/IS3dJDTSRkZG69tprJZV0T/zjjz8cXrd79+7213v27Dnj/d9//92e1L3hhht02223VbitqKgovfbaa6pbt64sFkuVLYfGjBkjo9GoX3/9VUuXLnU4Zk8L1vorj8FgUN++fSWVtDqo6Lj9v//7P8XExOiff/6pcvwud7lTv86644471KBBA+Xk5Gjy5MlOr//f//5X//zzj6SSc2nz5s0rXT46OlovvPBCpWNZesobb7yh7OxsRUZG6u2339ZZZ51V6fK1atXSO++8o5o1a0oqGS90zZo1kko+/+uuu67S9Q0Gg+644w7deuut9t9583ro7mfnDf369VNERIQsFkuVD7eWLFminJwcSbI/8PAV23mosLDQ3s3RFeedd54k2ffDU3bs2GF/7ch4Vad393rllVdUVFSkunXr6q233rIf0xVp2LDhGYn0L774Qrt375ZUktw5//zzK1w/KSnJ3jrm0KFDeu+99ypcNiYmRv/3f/8nSfrkk0904MCBSmMLFsFwjxYsvFmXjnr++edVu3ZtZWVllWmNPWfOHHsSa/z48ZWO8R2o/HmsBss1whnunK/Dw8P1yiuvKDIyUr///vsZLdcmT56sHTt2KCoqSq+88kql9w/9+/eXwWDQkiVL7EPelJaZmakNGzYoJibG/h041Fx99dU6//zzZbFYlJKS4u9wQk50dLRefvll+5Az06ZN0/Hjx/0blJ+Q2AwyPXr00MUXXyyppMu2o1auXGkfz2n48OFntF4pz/333y+ppAuqr25cHn74YYWHh2vXrl1auHChT8p0VX5+vr37gu0GxHYB++677zzWWueBBx6QVNLs3JU6iYyMtHcry87O9khM3lJ6UixnYi3dUrK4uPiM923dq41Go/3LW2Vq166tO+64Q5L066+/VvoQoUWLFvaxJN944w2vtuSrSjDWX0VKJ7wq2pc6derorrvuklRyIT+9BYenuVq/zoqMjNTo0aMllSQy/v77b4fXLSoq0ueffy5J6tq1qzp16uTwut4ecuTw4cP2lh59+vRxajgVW2tS2zAlNWvWdGiYCJvS++bN66E7n5231KlTRz179pQk+0QxFbHtW/v27dWsWTOvx1ZaVechR9lahLgyXI+jbA8OHPXLL7/YW7wPGjTI4bH/Tv+btJ2Lk5KS7PcdlenUqZO9m9js2bMrvT7dcsstOvfcc5Wfn1/p8B/BIlju0YKBr+qyKnXr1rUPzbBo0SKtWLFCGRkZmjBhgiTp1ltvLfOgNlj4+1gNlmuEq5w9X0tSs2bNNGbMGEn/G0tTKjmX2x4SjRkzRk2bNq10O0lJSbr44ot16tQp+/1PafPmzZPFYtF1111X4cRtoeDf//63pJKH0z/++KOfowk9JpPJPh5sdna2x3usBAsSm0HI1mpz48aN9pYrVfnhhx8kldwk27pyVKVTp072hJiz3Uld1bhxY3uXiLfeeuuM5v+BZNmyZTKbzTr33HPt46YkJSWpQ4cOKioq0vz58z1STrt27VS3bl1JculikJOTo2PHjklSlRMy+FvpsWWciXXt2rX21+XNIms7/s8777wqZ5m1ufrqq89YvyKjR4+WyWTSvn379MUXXzi0fW8I1vorz/79++2vK9uXYcOGqU6dOjpx4oTXu1+4Wr+u6N+/v5o3b67CwkKnhh5JS0vTyZMnJcnhc72vbNy40d4S35XYioqK7OfASy65pMrZiCvi7euhq5+dN9la1vz1118VXkf++OMP/fzzz5L8MyHEunXrJJUksV0ZwzMrK0uvvPKKvv/+e0mqcKxYV5UeeuPll192qnVe6XOgq3+XWVlZ9pbi//rXvxweOsJ2Ls7OztZvv/1W4XIRERF66KGHJEkLFiywtwwNVsFyjxYMfFWXjrj22mvt3S6fffZZjRs3TtnZ2WrUqJHXx772lkA4VoPhGuEMd87XNkOHDtXFF1+s4uJiPfroozp+/Lgee+wxFRUVqXPnzvZxBqtiq9vTH4parVZ7IjmQW796QufOne0PHZxpmAXHde/e3d56OFSvRVUhsRmELrzwQvuNcUpKikPj+tluUJOSkpyaqcrWpcuXN7gPPPCAoqOjlZGRUeFEJoHA1m3k9JmfvdE9xzZwtSutf2bNmmU/RsqbFThQZGdna9GiRZJKup860trm6NGjeuONN+xdZ1q1anXGAN6FhYX2mZcdmRnWJjk52T7TW1XHf8OGDe0tFCdPnlxudxNvC+b6O11RUZFmz54tqST51K5duwqXjY2NtY+B+NFHH1U5PpSrXKlfdxiNRj388MOSSrp+VZaQKK10XdvO34HC3dgyMzPtXeCcORYrisNb10NXPztv6t69u70VdEXXJtvvY2JiKu3if9NNN6lbt24V/rO1CnJUZmamnn76aXvy74orrlDt2rUrXeell14qU+aFF16o7t27a/r06erYsaNSU1N1/fXXOxVHVRo1aqSbb75ZkrRr1y5dd911GjBggJ5//nnNmTNHu3btqvB+zHbMmEwml1s5lR4mxJm/n9ITX+zatavSZa+77jq1adNGxcXFQd9lMFju0YKBL+vSEc8884wSEhJ05MgR/fTTTzIYDJowYYJq1Kjh0zg8JRCOVU9eIwKBO+drG4PBoJdfflk1atTQvn371K9fP+3du1exsbGaMGGCww+XrrnmGsXGxurHH39Uenq6/fcbN25Uenq6GjdufMZ4yqFo7NixMhgM2rp1q1asWOHvcEJOjRo17I1PKroWnX7vVN6/YEZiM0g9/PDDCgsL044dOyqcfbM021gLzs50afty4cuxGhISEjR06FBJ0tSpUwOy+3R6ero2bdokg8Fwxo3Iddddp6ioKP3xxx/asmWLR8qztQ47ceKEQ8sXFxfrr7/+0ttvv6033nhDUslnbxvEOpCYzWZt2LBBQ4YMsXcPHTx4cLndYkt/ob7ooovUtWtX+xhkCQkJ5T4FLF1nzhz/RqPRXu+OHP8jRoxQbGysDh06pA8//NDhctwVKvUnlYxduXXrVg0fPtzenbR///5VJjluu+02NWrUSHl5eRXO4ucqZ+rX06688kpddNFFslqt9jEhq1K6rgOthXbp2FyZddlT++aL66Ern503GY1G+/l/2bJlZ0zOU1xcrAULFkgquYZVliA4duyYDh8+XOG/qq5Tpyckr7jiCvuDjKZNm54x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V199pa+++koGg0FxcXHKy8srM9Nms2bN1LFjxzPi8OT1sCrOfHY2rjwIdNRNN92kF1980V7PAwYMsF+LHFm3qmWffPJJ9erVy+m4WrRooZ49e+qbb77R1KlTdeONN5b7pf+ll14q0xreYrHIbDbbP7Po6Gj95z//UYsWLZyOoSLh4eGyWCxavXq1fZgL2zF74sSJMg8G2rRpo7fffvuM42XgwIGqX7++nnvuOWVmZuqFF17QCy+8oMjISEVFRZU5j4aHh9sTNaUlJydr9uzZevjhh5WWlqa3335bb7/9tqKjoxUWFlZmnOTGjRtr0qRJateuncv7fc8992jWrFkOz8TuzeO2MoF+j+avenGFJ+vS3etjQUGBHnvsMRUVFenCCy+0jwlenkceeUTr1q1TRkaGnnrqKb333nuu7L7XBfqxatueq9eIQOCJ8zW8KyIiQg8++KD9YaS3BdM5+HTdunWzvy4oKFB2dnaZoWpq166thx56yD7jfEVOv3cqz3XXXaennnrKvYD9hExJiAgLC9OYMWPsLTcrM3z4cPXr109ffPGF1q1bp7///ltms1mxsbE6++yz1aVLF9100032bg+Vue2229StWzd9+umn2rhxo32W2Ro1aqhFixbq3Lmz7rjjDiUlJbm1fx06dFDPnj3t49H4g+3pas2aNcucYCrTsmVLNWvWTHv37tWcOXPOuBEp3eU3OjpaderUUWJios477zx16tRJV199tV/GCAtWd999t2bNmqWcnBxNmzZNjz/+eJn3o6OjNWnSJN15552aP3++Nm7cqIMHDyonJ0f16tVTkyZNdNlll+mWW25RfHy82/GMHTtW33//vU9awnlCoNWfOx544AEtXLjQodlY3RUeHq6XXnpJN9xwg+bMmaMtW7YoKytL2dnZqlWrlpKTk3X55ZfrlltusU/s46qhQ4fq448/tne1rUyzZs00d+5cfffdd1qxYoW2bNmiw4cPKzs7W7GxsUpKSlKHDh3Ut29fn3TBKq1Dhw5asmSJli5dqm+//Va//PKLjhw5olOnTik+Pl5NmzZVp06d1K9fv3KvRbGxsXrjjTe0c+dOLViwQJs2bVJmZqbMZrMiIyPVqFEjnX/++br22mvVvXv3Cr+QefJ6WBVHPrvSrU4rmxnYXX369NGrr75qTwA708Xw9KEqyuPO392IESP0zTff6J9//tFnn31mb/FVWnZ2dpkEnsFgUI0aNXTuueeqa9euuv32250ex7Yq3bt31/Lly7V69Wr99NNP2r17t/755x+ZzWZFR0fbr91XX321rr322gq/JF911VXq3r27Fi5cqDVr1ui3337TsWPHlJOTo7p166p58+bq0qWL+vXrpwYNGpS7jXPOOUdz5szRN998o6VLl2rbtm06fPiwCgsL1bBhQ7Vp00ZXXXWVrr/+ercfisbGxmrkyJGaMGFCpcvZWjvbZsL2tUC8Rys9TJO/6sUVnqxLd6+Pb775pnbv3q2oqChNmDCh0uRabGysXnrpJQ0bNkxr1qzRnDlz7N2qA0kgHqunc+caEQg8db6Gd11//fV6//33tWPHDq+V4e9rkyfYJv0yGAyKjo5WvXr11LBhQ5133nnq2rWrrrjiCodafp9+71TRMsHKYA2Wb9wAAAAhbPLkyXrrrbcUHh6urVu3KiIiwt8hAVUqLi7WBRdcoMLCQj3wwAMaNWqUv0MKCAcOHNDll18uqaR79A033ODfgACgGuHaVL3weAIAACAA2GaxT05OJqmJoPHzzz/bWxvbxuaD7DPSS9QLAPga16bqha7oAAAAfpSdna2ZM2faZ1/v3bu3nyMCqma1WrVjxw4988wzkkrGkr300kv9HJX/FRcXa/PmzZo0aZKkkmFB+FINAL7Btal6IrEJAADgBwcOHNANN9ygo0eP2n/Xtm1b+0zUQKAaP3685syZo9zcXEklY70/++yzXh0bNhg88MADWr16tX1ct6ioKL3wwgt+jgoAqgeuTdUXiU0AAAA/KC4u1tGjRxUTE6NzzjlHV199tYYNGxbUg9yjesjOzlZBQYHq1aun9u3ba9iwYerQoYO/w/I724zLZ511li6++GLde++9atGihb/DAoBqgWtT9cXkQQAAAAAAAACCDpMHAQAAAAAAAAg6JDYBAAAAAAAABB0SmwAAAAAAAACCDolNAAAAAAAAAEGHxCYAAAAAAACAoENiEwAAAAAAAEDQIbEJAAAAAAAAIOiQ2AQAAAAAAAAQdEhsAgAAAAAAAAg6JDYBAAAAAAAABB0SmwAAAAAAAACCDolNAAAAAAAAAEGHxCYAAAAAAACAoENiEwAAAAAAAEDQIbEJAAAAAAAAIOiQ2AQAAAAAAAAQdEhsAgAAAAAAAAg6JDYBAAAAAAAABB0SmwAAAAAAAACCDolNAAAAAAAAAEGHxCYAAAAAAACAoENiEwAAAAAAAEDQIbEJAAAAAAAAIOiQ2AQAAAAAAAAQdEhsAgAAAAAAAAg6JDYBAAAAAAAABB0SmwAAAAAAAACCDolNAAAAAAAAAEGHxCYAAAAAAACAoENiEwAAAAAAAEDQIbEJAAAAAAAAIOiQ2AQAAAAAAAAQdEhsAgAAAAAAAAg6/w+gYkRpTmu96gAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1350x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import pandas as pd\n",
    "\n",
    "\n",
    "import json\n",
    "with open(\"./LTW/eval/token_pos.json\", \"r\") as f:\n",
    "    data_dict = json.load(f)\n",
    "\n",
    "del data_dict[\"X\"]\n",
    "del data_dict[\"SPACE\"]\n",
    "del data_dict[\"PART\"]\n",
    "del data_dict[\"NUM\"]\n",
    "\n",
    "\n",
    "df = pd.DataFrame([\n",
    "    {\"Category\": key, \"Value\": value}\n",
    "    for key, values in data_dict.items()\n",
    "    for value in values\n",
    "])\n",
    "flier_props = dict(marker='o', markersize=0.2, markerfacecolor='red', linestyle='none')\n",
    "\n",
    "sns.set(style=\"whitegrid\")\n",
    "# 绘制箱线图\n",
    "plt.figure(figsize=(13.5, 5))\n",
    "sns.boxplot(x=\"Category\", y=\"Value\", data=df, flierprops=flier_props, width=0.6)\n",
    "\n",
    "\n",
    "plt.title(\" \", fontsize=22)\n",
    "plt.xlabel(\" \")\n",
    "plt.ylabel(\"Output Value\", fontsize=20)\n",
    "plt.xticks(fontsize=18)\n",
    "plt.yticks(fontsize=18)\n",
    "plt.tight_layout()\n",
    "plt.savefig('./LTW/eval/boxplot.pdf')  \n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "markllm_env",
   "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.20"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
