{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fbaea8ec",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Note: you may need to restart the kernel to use updated packages.\n",
      "Token is valid (permission: write).\n",
      "The token `all` has been saved to /root/.cache/huggingface/stored_tokens\n",
      "Your token has been saved in your configured git credential helpers (store).\n",
      "Your token has been saved to /root/.cache/huggingface/token\n",
      "Login successful.\n",
      "Note: Environment variable`HF_TOKEN` is set and is the current active token independently from the token you've just configured.\n",
      "mghareeb32\n",
      "Note: you may need to restart the kernel to use updated packages.\n",
      "Note: you may need to restart the kernel to use updated packages.\n",
      "Note: you may need to restart the kernel to use updated packages.\n",
      "Reading package lists...\n",
      "Building dependency tree...\n",
      "Reading state information...\n",
      "dvipng is already the newest version (1.15-1.1).\n",
      "texlive-latex-extra is already the newest version (2023.20240207-1).\n",
      "texlive-fonts-recommended is already the newest version (2023.20240207-1).\n",
      "cm-super is already the newest version (0.3.4-17).\n",
      "0 upgraded, 0 newly installed, 0 to remove and 12 not upgraded.\n",
      "Note: you may need to restart the kernel to use updated packages.\n"
     ]
    }
   ],
   "source": [
    "%pip install -Uqq huggingface_hub\n",
    "!git config --global credential.helper store\n",
    "!unset HF_TOKEN\n",
    "!huggingface-cli login --token \"INSERT_HUGGINGFACE_API_KEY_HERE\" --add-to-git-credential\n",
    "!huggingface-cli whoami\n",
    "%pip install -Uqq ujson ipywidgets\n",
    "%pip install -Uqq seaborn scipy imageio accelerate bitsandbytes transformers huggingface_hub[hf_xet]\n",
    "%pip install -Uqq matplotlib datasets google-genai\n",
    "!sudo apt-get install -yq dvipng texlive-latex-extra texlive-fonts-recommended cm-super\n",
    "%pip freeze > requirements.txt\n",
    "from utils import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "6da4287a",
   "metadata": {},
   "outputs": [],
   "source": [
    "from utils import *\n",
    "\n",
    "# MODEL_NAME = \"facebook/opt-125m\"\n",
    "# MODEL_NAME = \"facebook/opt-2.7b\"\n",
    "MODEL_NAME = \"meta-llama/Llama-2-7b-hf\"\n",
    "TOKEN_COUNT = 38\n",
    "PATTERNS = {\n",
    "    \"AA (KGW)\": {\n",
    "        'fn_colors': fn_colors_random_slow,\n",
    "        'colors': (\"lime\", \"red\"),\n",
    "        'pattern': (0,0),\n",
    "        'thresh': .7,\n",
    "    },\n",
    "    \"AA (Unigram)\": {\n",
    "        'fn_colors': fn_colors_fixed,\n",
    "        'colors': (\"lime\", \"red\"),\n",
    "        'pattern': (0,0),\n",
    "        'thresh': .7,\n",
    "    },\n",
    "    \"AB\": {\n",
    "        'fn_colors': fn_colors_random_slow,\n",
    "        'colors': (\"lime\", \"red\"),\n",
    "        'pattern': (0,1),\n",
    "        'thresh': .7,\n",
    "    },\n",
    "    \"ACBC\": {\n",
    "        'fn_colors': fn_colors_random_slow,\n",
    "        'colors': (\"lime\", \"blue\", \"red\"),\n",
    "        'pattern': (0,2,1,2),\n",
    "        'thresh': .3,\n",
    "    },\n",
    "    \"ACADBCBD\": {\n",
    "        'fn_colors': fn_colors_random_slow,\n",
    "        'colors': (\"lime\", \"blue\", \"yellow\", \"red\"),\n",
    "        'pattern': (0,1,0,2,3,1,3,2),\n",
    "        'thresh': .3,\n",
    "    },\n",
    "}"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7994d4ff",
   "metadata": {},
   "source": [
    "# Figure 4: Edits"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b24e7ffa",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "MEANINGFUL_EDIT on AB\n",
      "  PROMPT: World War II dramatically changed the lives of...\n",
      "  LLM: ...millions of men, women and children in Europe and around the world. nobody was spared the ravages of this terrible war, not even \u001b[31mbabies\u001b[0m in the womb. The\n",
      "  Edited: ...millions of men, women and children in Europe and around the world. nobody was spared the ravages of this terrible war, not even \u001b[32minfants\u001b[0m in the womb. The\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 650x155 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "MEANINGFUL_EDIT on ACADBCBD\n",
      "  PROMPT: US President Barack Obama announced that former...\n",
      "  LLM: ...UN Ambassador and Chicago mayoral hopeful Carol Mosely Braun was appointed to his cabinet as White House Chief of Staff to replace Josh Bolten, who decided to go back to private life\n",
      "  Edited: ...UN Ambassador and Chicago mayoral hopeful Carol Mosely Braun was appointed to his cabinet as White House Chief of Staff to replace Josh Bolten, who \u001b[32mhad\u001b[0m decided to go back to private life\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA6wAAACRCAYAAADHNzWqAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjMsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvZiW1igAAAAlwSFlzAAAPYQAAD2EBqD+naQAAOHZJREFUeJzt3V1wHOd5J/o/SJPUh0k2B3Yc8agSoiexV3HsiA1ASSlRlUroiXKxVc4hZwTdaC9Y5AxFkbWnZBojuGrX8W4VwYGYqrMlSmYPULxYX6yAGWFzsRdrT0MlRVklETBNlawNNy5Pg96jpeJQGDQp64NiiD4XYDfno6f77Z4BMEP+f1UsAj399Pt2vw8G8+Dtjz7btm0QERERERERdZktm90BIiIiIiIiIi8sWImIiIiIiKgrsWAlIiIiIiKirsSClYiIiIiIiLoSC1YiIiIiIiLqSixYiYiIiIiIqCuxYCUiIiIiIqKuxIKViIiIiIiIuhILViIiIiIiIupKX9rsDnSjy5fbCN7bTnAbzUYNbKO7l6O3ir3tNByx2bZG5nL0fW0nJziuwTiuoqEcVyEc1/XVxtBsSk5sRj4A7e3s3rZaJiLqOpxhJSIiIiIioq7EgpWIiIiIiIi6EgtWIiIiIiIi6kosWImIiO5AN27cuKvaJSKiOxMLViIiojvMq6+exze+vhOvvnp+Q9s9/+qr2PmNb+D8q69uaLtERHTnYsFKRER0B3n11fM4efIw4l/EcfLk4Q0rWs+/+ioOnzyJeDyOwydPsmglIqKOYMFKRER0h3CK1Yx9FO/hPWTsoxtStDrF6tFMBu+99x6OZjIsWomIqCP4HFYiIqI7QG2x+jLOYgu24GWcBWzg5MnDAICnnz7U8XZri9WzL7+MLVu24OzLLwMADp88CQA49PTTHW+XwrFtG//yL/+CmzdvbnZXiIiwbds2bN26VWhdFqxEREQ9zqtYBbDuRatXsQqARWuX+eKLL/Dhhx/i008/3eyuEBEBAPr6+vDggw/iy1/+cuC6LFiJiIh6WKti1bFeRWurYtVt16tofZ5F60ZbXV3F0tIStm7dir1792L79u3o6+vb7G4R0V3Mtm1cuXIFH3zwAX73d383cKa1z7Zte4P61jMuX24jeG87wW00GzWwje5ejt4q9rbTcMRm2xqZy9H3tZ2c4LgG47iKhnJchfTYuP7yxlfxja/vRPyLON7De9iK1r/0b+Imvo1vo7K9gn/8+cf47W1XIrd748YN7PzGNxCPx/Hee+/5fti4efMmvv3tb6NSqeDjj/8R27Zti9TmpuTEZuQD0N7O7q1v+fPPP8fS0hJ++7d/G/fdd1/kzd64cSPy2BERNfrss89w6dIlDAwM4J577vFdlzddIiIi6lHbtm3DqYlXcLHvIo7jBFax6rneKlZxHCdwse8iTk280nbhsW3bNrxy6hQuXryIE8ePY3W1Rburqzhx/DguXryIV06dYsGziRpnwMM4f/48du7cifPnN/YxSUR05wpzpgcLViIioh729NOHcObMNLS+c3gOx5uK1lWs4jkch9Z3DmfOTHfsGtZDTz+N6TNncE7TcPy555qK1tXVVRx/7jmc0zRMnznDa1h71Pnz53H48OG1xxUdPtzRorVYLCKVSiGfzyObzWLPnj3I5/PI5/MYHByEaZoda8thGAZSqRTi8bjb1uTkJLLZbMfbChKPx2FZ1oa3eye628bVMAzE4/GO/4xE2W6rGMuykEgkMDk52Xa/OnoN66VLl7Bv375ObpKIiIgCOEXoyZOHARvutazrVaw6nCLUuUbVuZaVxeqdwSlWjx49ipdeegknTpzA4cNr10EfOtR+LlWrVRQKBQBrH27z+TzS6TQAYGhoCKZpQpblttuppSgKMpkMcrmc2xaw9qE7kUigVCq1jM3n81BVNVKfvGJLpRIkSQq9LWp2p49rYzuKokBRlI62EXW7rWIkSUImk+lIUd3WDOu7776L119/3f23GX/FICIiouaZ1pu4ua7FqqNxpvXmzZssVu8AtcXq2bNnsXXrVpw9exZHjx7t2EyrX4GwHh/G/SiKgmq1Cl3XW66jaVrk7XvFdroYp2Z3yri208c7QeQZ1qeeegqWZdX9BeHChQu+MS+88AJ+53d+B6lUCqlUCnv27MHo6CgOHDgg1KZhGDhy5AjK5bLveqZpolgsQpZlmKaJdDrNv2AREdEdr3am9a/tN3Gx7+K6FquO2pnWN//6r3Hx4kUWqz2ssVite1zR2bMA0JGZVlVVA9fZs2cPCoUCNE1DJpNBLBZDKpVCoVCAoihIpVKIxWLuB/psNuuekinLMpLJZKj+lEolqKratB1JkmBZlvv50tmuV3vFYhGmaboxiqI0xTqnsJZKJciyjHw+j1gsBmDtc+zY2Ji7TjabRSwWw8zMDMbHxze8mA+y+tlnuL4Op2/X2iHL2HLvvZFie31cdV337KPzWuM2dF13f0acnxuvfZdlGYuLi5BlGYVCAblczq2XvLYLwHN/GuXzeQBALBZDqVRCPB6PNG61IhesiUQCR44cqVv22muv+cYMDw/j4MGDePHFFzE4OIiJiQlMTU0JtecMkmEYgeumUim3qDVNE0eOHHFPOSEiIrqTOcXp98eP4czE+herDqc4Pfb977NY7WGtilVHp4tWP6qqYmhoCAAwNTXlfpiu/WCfyWTcz3jOB2XnlNBEIhGqYHV4bccpQJLJpDuD5rWeoijQNM09BXVwcBBjY2NNsbWnURaLRVQqFXc7zjWY6XQaiqIgFoshmUxCkiTMzMx0XcF63TRx6WD44xzGvteKuPeb32xrG706rs6pwLXtOLy24fVz02qf4vE4hoaG3OLdb7t+++PQdR2lUsn9maxWqx25njdywepVLQdV0Hv27AEAzM7OuoWqU6UHEX3DaTxPWpZl39MAiIiI7jRPP30IBw8+s+F35T309NN45uBB3g24R924cQPHjh3DQw89hJdeeqnlnYW3bNmCl156CW+++SaOHTuGZ55Z31xr/DDdijNZ4XzuC3upmmEYyGQyblEStB2v9jRNQyKRaFrHT6lUqouRZbnuWszaIqUbb9K0Q5ax77XiurcR1Z08rn7bqP258dqnoaEhTExMYGRkxJ0N9dtu0P446wwPD7vfx2KxzS1YK5UKNE1zO2XbNmZnZ7GwsOAbY9s2KpUKHn74YSwtLWFlZSVqFzw5U9i1YrEYDMPour9IUe95++03hNd99NHH62PfeFss7vFHm5a9IRj7uFfs24Kxj9bHtrOvUdsE2tvXqMeY4+qtW8aVotmsopHFau/atm0bXnnlFRw+fBgnTpzwnGEFbj2u6MSJtVO/p6fXfcy9Ptc5as+8c2bMnFONRc7Kq91OtVp1J0j8tlMsFpFMJj3bi8fjdcVM4+VzTmytwcFBLCwsuMtN06wrDLrdlnvvbXv2c73caePq1U4rtT8nXvs0OzuLXC7nblfXdd/T9EX2Z3h4uK7wrVarWF5eFts5H5FvuqRpGgYGBmDbNmzbBgD3/1aeeuopXLhwAeVyGVevXoWmaR3/S1Gr7VWrVc/l169fx7Vr1+r+Xb9+vaN9IiIiIuoFhw4dwvT0NM6dO4fjHs/YXV1dxfHjx3Hu3DlMT0935HRgXdcxMTHh3inYKSQMw4Bpmu5rjlQqhZmZGRSLRSwvL0PXdRiGgWQy6T7WpFgsen72M00TmqbBNM26x5/MzMy4BUmr7WQymbqb33it59w3ZXJy0i0CvGKdfdM0Del0Gv39/e52KpWKe62jYRju5+VCoYDFxcV1edxPr7vTx9WrnVbb8Pq58dqnSqXifm+aJlRV9d2u3/44+9zYTrlchq7rbedsnx1UZbYwPz+PkZGRumUXLlzA/v37W8ZcvXoVU1NTSKfT2LVrF+bn5zE8PIxdu3aJd7ivz7cwnpycRKlUqqvu4/E4crmc518k/uIv/gI//OEP65Y9//wP8N3v/oVwn+rsvRwtrk17owa20d3L0VvF3nYajthsWyNzea3RSLNTt3Iiykycs6uhZ6dqdjbsrJgzrlH21RnXSDNxt3Y27L7WjmvoY8xx9dUt4xra5ejvTe28h99V78PRG41sU3JiM/IBaG9n99a3/Pnnn2NpaQkDAwO45557hDfjdS3rehSrRHR3CvPeFPmU4JGREVy7dg2zs7MA1mZP/YpVYO3a1Y8++qhuG3Nzc8J3CRYhSVLTX9Sq1WrLax/Gx8fx/PPP1y1bXt7Rsf4QERER9RqnGHVurOQ8h5XFKhFttMgF69LSElKplHtRbi6XQ6FQwMMPP9wypr+/v+nOwp2mqqrns4qcu2U12rFjB3bsqC9Qf/3rdekaERERUc+oLVrffPNN95pVFqtEtJEiF6yvvfYaFhcX65aNj4/7FqzvvPMOEokEdu7c6S5bWFgIPcPaeKGzYRiQJMl9plAt0zQxNDQU+TmsoqfPNd6chLpbOzfKIaKNxZ9Xulu1c6OzTnGK02PHjrFYJaJNEblgHRgYaFrWahbTkclksH//fsTjcUiS5F7UK8J5rg8ATExMYHh42L0m1fneeXhtoVBANpvF8PAwFhYW+AxWIiIioogOHTq07o+uISJqJXLB6nW3p6WlJd+YgYEBlMtlzM7OwrIsnD592rPw9aKqKlRVdW+/XKuxIHWeCwSIP7+ViIiIiLyxWCWizRK5YFVVFX/6p3+KwcFBAGszoF7FZKPdu3fXXcd66dIl7Nu3L2o3iIiIiGid3bhxg0UrEW2KyAXr/v37oWmae0pvPp9vukvw3NwcVFV1H1szPT1d97plWSiVSvjJT34StRtEREREtI7Onz+PY88ewys/eoXXsBLRhotcsAJrp/iePn3a/b5xtvTUqVOQJAlPPPEEAODcuXMYHR2t28by8nI7XSAiIiKideI8j/Uh+yH3ETedKloNw8DExAQMw0A2mwWwNpmhaRpKpVLTjTSdmFQq1fL1qOLxOMrlctNNPdejrTvRG2+8sW7bfvzxxwPXce6LMzs7i6WlJXccJycnMTMzg1wuB1VVO9Ify7KQSqWQSCTc++d45U8729ts3dYn4YI1ymxp412Ep6ammmZhO5U83Ub0rpZA850t27kj5huCsY97xUa8G6HonZSB5rspt3MHxHb2lYjufO28NxF1iujvKqD7fl85xepR+yhewks4YZ/oaNGqKApGR0dhWRbS6bS7XFVVmKbpWSQqigJFUdpuu5au65AkCbOzs3X9WI+2aH0oioJEIoF4PO7+kQEAxsbGIElSR+sNSZKQyWTq7udTKpXcYjWfz0NVVeE/cnhtz0vY7bYTK9qnjbJFdMVTp07VFaDnzp3DysqK+8+27cDZ0j179rhfX716Fa+99lrdMiIiIiLafLXF6lmcxVZsxVmcxVH7KA4fPozz58+vS7umaW54kWiaJnK5nPCTK6h7ObOB+Xx+Q9utLQTXK4/a2W6v57bwDGsnZkt1XXf/Mrd7924cPHgQ09PT7jIiIiIi2lyNxeqWW/MbW7AFZ3EWsNHx04OBtdM6FxcXkU6noaoqstksEokEDMOAoihNnzOd9WVZRqFQQC6XgyRJyGaziMfjsCwLsiz7PjHCsizEYjF3VrfVzC4Az/7ouo5UKoVCoQBN05DJZBCLxZBKpZDNZhGLxVAqlZBKpWBZFkzTxPLystCNSimaQqGAgYEBzxnFfD6PWCwGYO0PFa1Od/XKIacIdsY0Ho8DqD913DRNWJaFYrEYmHuttufVviRJntv16mexWIRpmm6MoijCsX592kyRr2FtnC3Vdd29Y3Ctq1evYnZ2Fn19fe70fK1yucyClYiIiKgLtCpWHetRtJqmiXw+j0qlUvcBub+/3y06UqkUyuVyXdzMzAzi8TiGhobcD/XOB27n1N5EIuFbNOi67r6eTqehaVrLYtKrP6qqYmhoCMDaZI5zWqiiKIjFYkgmk5AkCblczv0cHI/HWbCuI0mSMDU1hUQigUql4i4vFouoVCpubuTzeeTz+brTwJ3lQH0OSZKEUqnkPkqzWq3CsiwA9aeOO/mRTCZ9T7/Vdb3l9rzad66jrt2u13qKorjXgAPA4OAgxsbGhGL99nGzRS5YRWdLd+/e7T4/tVKpND13tRsu5CUiIiK62924cQPHnj2Gh+yH8BJeaipWHVuwBS/hJbxpv4ljzx7DM88809Yjb2RZdj8467pe95ozI+b1wXl8fBwTExMYGRlxZ4ScotbZjnMzp1YWFhZQrVYBrBWkExMTvsVkq/44BXPjMq+vaf0lk0mUSiV3FhFYu840kUi468iyjFwu11SweuVQqVTC8PCwu06rnBTltz3RHPZaT9O0un1s/COPX2yn97GTQhWsUWdLBwYGcO7cOczPz2NkZCR6b4mIiDZAOze/ozvT3ZAT27Ztwys/egWHDx/GCfuE5wwrAKxiFSdwAhf7LmL6R9MdfT6rc9pvPp/H8vIyxsbG3A/Nzqm4jtnZWbe4LBaL0HXdnY1ytmMYRsu2TNPE6Oho3TZnZmag63rT6cdB/XFOM6XuoWka4vE4MpkMgLXZxoWFBXdG3TTNuuLO4ZVDw8PDdbVPtVoNvHdPsVhsObvvt72gHHa267Wec7dih2VZdX9I8YuNso8bRfimS8Dt2dLFxUVUKhX84he/qPsXNFtaKpUwPT2Na9eu4cknn8To6Cjm5uba2gEiIiIi6oxDhw5henoa5/rO4TiOYxWrda+vYhXHcRzn+s5henq6rdOBTdPEzMyMe0pw7WyOc02pU4gqigJd12EYBkzThKZpqFQqyOfz7jV7qqoimUwiHo+7y53Z00bOtae1M7qmaSIWiyGbzTa1FdSfiYmJukLWecyKZVkoFApYXFyEYRjQdd3dDnWOc7wzmUxdHhUKBbdgS6fT6O/vd3OjUql41i5eOdS4rFwuu2NZmycAkMlkAm9y5Le9VjncuF2v9dLpNCRJwuTkpJurorF+fdpsoU8Jbme2dHh4GAcPHsSLL76I/fv34/Tp05iamgrbBSIiIiJaJ04RevjwYcCGO9PayWIVgHuzJJHXameqWp3m6BC53ExV1abtyLLcdAZh7Tqt+lN7nSSwdk1j7bLG4sW27cD+9RqRZ6WuJ0VRPM/+bHw0UW1u+F3b7JVDfrG1eZJMJn23LbK9VoW0yHpep7SLxooen40Waoa11tDQEM6cOYNr164BAF5//XX361acGzXNzs7i6aefBsBTKIiIiIi6TeNM603c7GixSkQkKvJNl2ZnZ/HRRx+53z/xxBOYm5vDgQMHWsZUKhXYto1KpYKHH34YS0tLWFlZidoFIiIiIlontTOtb9pvrl2zymKViDZY5IK1v78fR44cCRXz1FNPIZ/Po1wu4+rVq9A0DV/5yleidoGIiKjrvCF4c57He/jmPL3q7bffEFrv0UcfX9d+9BKnOD327DFM/4jFKhFtvMinBL/zzjv4+OOP65YtLCz4xuzevRvf+973MDAwgN27d+P06dNddX40EREREdU7dOgQPv71xyxWiWhTRJ5hzWQy2L9/P+LxOCRJcu/OVWtubg6qqmLXrl0AgOnp6brXLctCqVTCT37yk6jdICIiIqJ11slH1xARhRF5hnVgYADlchnJZBJDQ0P46U9/iieeeKJunVOnTmFxcdH9/ty5c1hZWXH/2bbdNc/3ISIiIiIiou4SeYYVWHuI8uLiImZmZjA/P4/+/n53NhVAXbEKAFNTU9i/f3/dssYHMxMREREREREBbRSsL7zwAuLxuFtwjoyMBN4l2HmsDQBcvXoVuq5jcHAwaheIiIiIiGiTXfxXD63bth/6XxfXbdvUGyIXrMPDwzh48CDm5+eFY3RdX3sINdZuwHTw4EFMT0+7y4KYpolisQhZlmGaJtLpNCRJatkWsHad7MLCAkZHR+seHExERNRN3nhb7O7CAPD4o3fvHYbfFrwLMwA8yjsxt+3mzZt466238OGHH+KBBx7AY489hq1bt3Zk26ZpIpvNQtd1z8ccJhIJAEAul4OiKIjH4yiXyy0/+4VlWRZSqRQSiQTGxsaaXjcMAxMTEzAMA9ls1o1ZXl5GLpfrSB/C6PT+30lajdXMzAzGx8frbvLqNe5Rj21QDm2GbuxTuyIXrEtLSwCAvr4+d9nCwkLTDOvVq1cxOzuLvr4+lEqlpu2Uy2XhgjWVSqFcLgNYe5M7cuQICoVCy3Xn5+ehqiqq1SpSqRQqlYpQO0RERER3u7m5Ofzb734XH1y65C57cN8+/Ke//EvfM+pEybKMTCaDWCyGfD6PdDrtvmYYBmRZRjwedyccSqVSR4s1SZKQyWRgmqbn64qiIJPJIJfLNfUtkUh4fq515PN5qKoKWZYj9c0rvtP7fydRFAWjo6OwLKturNLpNGZnZ+vW9Rr32mMbZuyCcsjRTj6EjRXtUy+JfNOl/fv3Y2hoCLlcDuPj4xgeHnb/ElZr9+7dUFUVi4uLqFQq+MUvflH3T7Tybzzosiy7s6heCoVC3Ywqf8CJiIiIxMzNzSGZTOKDb30L+Nu/BT7+GPjbv8X/+da3kEwmMTc317G2MplM05MmqtUq4vF43bKoxV+nKYqCarXq+zm0cX/C8orvlv3vFcViEZIkCR232nXaHTsv7WxzPfrTayLPsI6MjKBQKEDTNNi2jXw+33RDJcfAwADOnTuH+fl5jIyMRGpP13XEYrG6ZbFYDIZheJ7qW3szp0KhgEwmE6ldIiIiorvJzZs38W+/+13Y//pfA3/1V8CWW/Mbf/RHsP/qr9D353+O/+fkSXznO9/pyOnBsixDlmX3M51lWU2f+QzDQCqVQqlUgmVZWFxchCzLKBQKyOVyME2zaZkkSchms4jH47AsC7IsI5lMIp/PA1j7HFkqlZoKYxGqqqJUKkFV1aY2JEmCZVnuZWzO6ahefSkWizBN040ZGxuDrutN8bX7L8sy8vm8e4xM08TY2Ji7TjabRSwWc0+HvZsuiTNNE/l8HpVKBf39/QBu1wStxr322Jqm6Tl2jfxyqJP54Pw8iMR2Iq+7VeSC9dKlSxgYGMDp06fdGyjt2bMH+/btaxnTWKy+/vrrsCxL6LQSy7I8l1er1ZYxhmFgZmYGiUSi7vSAWtevX8f169frln36fgU7tm8HAKx+sBTYNwC4+fOvrn2xcmUtbukDoTgAuPnVn9d9LxpbG/fZrf+vC8Z+5sReub3s+geCsT9fi72JtetNRI8RcPs4fXar4bBtAsCtZkPv682aZaGP8ZXo+xo2JziuHNdGHNe7Y1xFjy/QPK5RfFabUBslenfdnIj0+zVkTjTmQ5h2nTbD5gMQPSdqf+bu3btXuL1W3nrrrbXTgP/Lf7ldrDq2bIE9Po7/79FH8dZbb+Hxxx9vuz3g9iyrpmlYXFyEqqp1M5iKoriF18zMDOLxOIaGhtyCwGuZ8wHe+QyYSCQgSRJKpZJ7SVm1Wm35GVOEVxtOUZlMJt2ZO6/1FEWBpmnuqcWDg4MYGxtzT/+sja/d/2KxiEql4m4rn8+7p1QrioJYLIZkMukel7upYJVlGel02r3vjUPX9ZbjXntsvY59I79trUc+iMR2Oq+7TeSCNeoNlObm5tzTe23bxuLiYlvXQfgNhqIokGUZ2WwWxWLR868kExMT+OEPf1i37Fh/P45/5dYHtU8/EerHr++7v+570bh2Ymvjfn3r/38SjL3U0GY7sVH2dTP7C3BcRWI5rp2N5bhyXBs17qtonFfsOyFiH2kY180Qpb+OjR7XqLFh8wGInhO1cZ24o+qHH3649sXv/773CreWu+t1gKqqyGQyQh+yx8fHMTExgZGREXc2yWuZc98Tp/DNZrMolUoYHh52txWLxSJ9sDcMA5lMxi0uatvw4tUXTdPqLqdz1glSKpXq4mRZrrvOtrbQupOKljBqZyOdGddOjDsA3xzyGmcv7eTDeuZ1twpVsLZ7A6UXXngBlmWhWq1ClmVYliV8qq4kSU2zqdVqNfDaVEmS3DtlraysNK0/Pj6O559/vm7ZP//d7RnWe999R6h/X374kbUvvrr2Z9F733lXKA4AvvzIw3Xfi8bWxn3l1v//WzB2nxNb8wf2//2uYOzDa7EfYa2oFz1GwO3j9JVbDYdtEwBuNRt6Xz+qWRb6GF+Jvq9hc4LjKhjLcRWL5biKxXbBuIoeX6Cz47qhQuYD0JwTkX6/hsyJxnwI067TZth8AKLnRN3PXAc88MADa1+8/z7wR3/UvML779ev1yGZTAZHjhzB1NSU73qzs7PuXXqLxSJ0XYdpmk3LnNkt55RQwzAwPDxc9xm2Wq1ieXk5VD8Nw0C1WnULosY2ajkTJl59ce5M67Asq+lzqteEy+DgIBYWFtzlpml63kfmbucU7k6xGnbcW012+W3La5y9thklH/xiO5HX3SxUwercQCmXy6FSqWBgYKDu9aAbKMXjcRw5cgRLS0vo6+vDvn378Prrrwu1raqq50XHQ0NDTct0XUcqlXJvke4krGmaTadF7NixAzt27Khb9uvfv30t7paPxH6hb/36N9e+2Ht5Le7KRz5rN8R+8+t134vG1sbde+v/HYKx9zqxl28v2/GRYOzX12K3Yu20I9FjBNw+TvfeajhsmwBwq9nQ+1p7lU3oY3w5+r6GzQmOK8e1Ecf17hhX0eMLdHZcN1TIfACacyLS79eQOdGYD2HaddoMmw9A9Jyo+5nrgMceewwP7tuH/3PqFOzaa1gBYHUVfRMTeHBgAI899lhb7ThFZu0MYaVSgSRJMAzD/QDufDA3TdP9LOhcw+lcv5nNZpuWOTHOckmSkEwm65aVy2UsLi7CNM2mU0Cd9pz1gduPtXEKi8btOQWGc4qzM+vltV46nUY2m8Xk5KTbtlMgNcYbhuH2J5fLYXJy0t1WpVJBLpeDYRgwDMNdp1AotNy3O41zGWDtMTZNE6VSCYqi+I67ZVl1x7bx2Dfy29Z65INIbJi87kWhTwlu5wZKsizjl7/8JQYGBnDmzBmcPHkyVGwt0zQxNDTkJoJhGO6dwGKxWN1Nl5zX7qZz+ImIiIii2Lp1K/7TX/4lkskk+v78z2GPj6+dBvz+++ibmAD+23/D/1sstn3DJVmWm87YcwpSRVGaXvM7ZbbVc1G9JlNql7W6qY7Tv1aPTwxqI5lMNm3ba71W/W6MVxSlbv+99kFRlLpHOG7k3WU7cSp6OxRF8Ryr2uPkN+61x9Zr7Py2KzLO7eSDaKxoXveiyI+1GRkZwYsvvojR0VEAwPz8PK5du+Yb49zJ6tq1a/joo4/w5JNPhvphKhQK7vWomqbVJebExIR7cbXzLCbnIvSZmRnh6wKIiIiI7nYHDhxAsVjE//WznwGPPgrs2gU8+igefP99FIvFjjyHlYhIROSbLo2Pj0OWZXcmc2RkBHNzc75vYAcPHsTNm2v3+Tt9+jTm5+c9T+ltxTllBGj+y0HjX1VqX291h2AiIqK73cUnxM6Weuj1+Y7GUvc7cOAAvvOd7+Ctt97Chx9+iAceeACPPfZYRx5lQ0QkKnLBOjQ0hIMHD2J+XvyX0KVLl9zH3ly9ehWWZWFlZQW7d++O2g0iIiIiWidbt27t2KNriIiiiHxK8NLS2rPM+vr63GULCwu+MbXP03IehVO7jIiIiIiIiMgReYZ1//79GBoaQn9/P0qlEnRd97xQuN1H4RAREREREdHdKXLBOjIygtnZWeTzedi2jXw+j/379zet1+6jcIiIiIiIiOjuFLlgBdZugnT69OnA9dp5FA4RERERERHdnUJfw3rt2jWcOXMGo6OjePLJJ/H9738fv/zlL4ViWawSERER9YbVL77AJ3/397BtGwBg2zY++bu/x+oXX6xLe/F4HJZlrcu2vRiGgXg8DtM0I8VbloVEIoHJyUl32UbvA9HdINQM64svvohsNgtFUSDLMnbv3o2f/vSn0DQNmUwGp06dqlt/amoKpmmiv78f6XQau3btwtzcHE6dOoWrV68imUxiYmKiozvUCT/7meF+bZo/F4rZuXPX2hf/dGUt7ufib347d+2s+140tjbun279/3PB2F1O7JXby34u+Ia9a+fOW6FrrYoeI+D2cfqnWw2HbfNW8FpsyH2t2dXwx/hK9H0NmxMcV45rI47r3TGuoscX6Oy43isYZ/zsZ03LQseGzAegOSci/X4NmRON+RCmXafNsPkARM+J2p85Ze9e4fb8rH7xBT547jl88tbfYM+/eQZfe+EF/GriNFZ+/GPc/9if4MGXX8aW7ds70hawdmNOSZIwOzsr9DjCfD4PVVUhy3LkNhVFgaIokeMlSUImk6kreEulEiRJ6lgfiShEwfraa69hYWGh5WNojh492vQcVlmWYVkWTp48CQCYn59HKpWCpmlIpVLQdR3j4+NdV7T+2Z8NbnYXiIiIusuf/dnmxFIozmxoO9xi9X+8DQBY+c8/xqfvvIPr/+sfAQCf/I+38cFzz3W0aDVNE7lcDtlsVqhg1TQNqqp2pO1Oqi1Ou7WPRL1GuGDVdR2zs7MtXz937hyeffbZuoJ1aWkJ3/ve99zvc7kcksmke1fggwcPolqtRun3uvrv/70cPfirV4LXWQdfjRrYRnevRG8VX22n4YjNtjUyV6Lvazs5wXENxnEVDeW4CuG4rq82hmZTcmIz8gFoc2fb95lxAZ+89Td1y5xiFQCwuopP3vobfHbhXdz/h4+03Z5lWYjFYlBVFaZpwjTNusKvWCzCNE1IkgTLsqAoCizLQrFYhCzLSCaTMAwDqVQKhUIBiqIglUohFotB0zQAQDabRSKRgGEYUBRFuJDMZrPuab5OW/l8HgAQi8VQKpUQj8cBwO1DqVSCaZpNfSSiaIQLVpHTGYLW0XXd/SF31D7HtVt861vRTw/B3sud60iYZqMGttHdy9Fbxd52Go7YbFsjc7mNU6zayAmOazCOq2gox1UIx3V9tTE0m5ITm5EPQJs72777/vAR7HnmGaz8+Mct19nzb57BfY8Md6Q9Xdfdgi6dTkPTNPdRiaZpQtM099GIg4ODGBsbc4tA57Nn4+m9mUwGhULB/b6/v989PTeVSqFcDp6ccD6zOjO+iUQCkiShVCq5265Wq+41q7V9cNqq7SMRRSNcsO7Zsyf0OisrK+7XU1NTAND0Fy1emE5ERETUPfr6+vC18Rfw6cI79TOrt+z4V9/A1154oWOTDgsLC+4Zd/39/ZiYmHALVk3TkEgk3HVFCs1W8vk8YrGY8GdPpy1d1wGszbaWSiUMD98u1MNsj4iiEb5LcKVSwccff4xr1661/FepVOpikskkhoaGMDw8jGw2i0KhgH379gEALly4gCeffNK9MJ2IiIiINp9t2/jVxGnPYhVYOz34V6dPd+R6WdM0MTo6inQ6jXQ67c6eOkViPB6v+3zZWBwWi0X361gs5n5tGLdvoJnP57G8vIx0Ou1OnNS+3opTKKuqClVVEYvFMDw8XNefarWK5eVl3+3U9pGIwhMuWHO5HCRJwp49ezz/SZJUd1tvYO35q4uLi5idnUW1WsXBgwcBAFevXgUAnD59GoODvMERERFRL1v94gt8cuFC/eNPLlxYt8ef0Pr69O/f8T0dGHBuxLTQVju6rrs34XSYpolYLIZsNgtd15FOp93PmMVi0V03k8m416c6UqkUZmZmUCwWsby8DF3XYRiGe22sE68oivuac8qxl2QyiXg8jnw+j2KxiGq12rSsXC5D13WYptm0Pa8+ElF4fbbgn8eOHj3qnp7hxbZtvPDCCzh37lzHOrdZLrdz7QivYRXCa+IEQ6MGclwFgzmuIjiugqFRA3txXGusfvEFPvh3/x6fLCxgz4ED+NqxZ/GrV17Bytx/xf3Dw3jwP/6H23eS5TWsYtr6HFLf8ueff46lpSUMDAzgnnvuEdpE3V2CV1cBrJ0G7M64btmC+//40Y4/2oaI7h5h3puEZ1gzmQx2797d8p/zLCoiIiK6O7jF6uIiAGBlbg5LmaNYmfuvAIBPFhfxwb/795xp7TFbtm/Hgy+/jPv/+FEAazdYGpibw55nngEAFqtEtKGEb7q0f//+jqxDREREd4bP/uf/xCcL9aeFXq+9n4Vt45OFBXz2D/+A+x9+eGM7R21xitbPLryL+x4ZXrsR0/fHsVNVce/+h1msEtGGEZ5hJSIiIqp138MPY8+B/9t3nT0HDuC+P/iDDeoRddKW7dtx/x8+4t4NuK+vD/f/4SMsVoloQ7FgJSIiokj6+vrwtWPHsCMe93x9RzyOrx17tiufuX636cQdfYmIOiXMexILViIiIorEtm386pVX6k8DrnG9UsGvXvkRi6VNtG3bNgDAp59+usk9ISK67Ytb9zbYunVr4LrC17ASERER1fr03XfdGyy1sjI3h51/8se8hnWTbN26FZIk4Z//+Z8BAPfddx9nvIloU62uruLKlSu477778KUvBZejLFiJiIgoknu/+U3cPzy8dpfgW7OoO+Lx2zOufX24f2gI9/7e721iL+k3f/M3AcAtWomINtuWLVvwW7/1W0J/QGPBSkRERJFs2b4dD/7H/9D6OaxDQ/XPYaVN0dfXhwceeAC/8Ru/gRs3bmx2d4iIsH37dmzZInZ1KgtWIiIiiswpWj/7h3/AfX/wB2s3YnruOez8kz/Bvb/3eyxWu8jWrVuFrhcjIuomLFiJiIioLVu2b6+7RrWvr4/XrBIRUUfwLsFERERERETUlViwEhERERERUVdiwUpERERERERdiQUrERERERERdSebQvn888/tH/zgB/bnn3++YbGb0eZmxfZaf9uJ7bX+thPL/nZvbK/1t53YXutvO7G91t92Ynutv+3EttMmEVGv6rPtW0/6JiHXrl3D7t27cfXqVezatWtDYjejzc2K7bX+thPba/1tJ5b97d7YXutvO7G91t92Ynutv+3E9lp/24ltp00iol7FU4KJiIiIiIioK7FgJSIiIiIioq7EgpWIiIiIiIi6EgvWkHbs2IEf/OAH2LFjx4bFbkabmxXba/1tJ7bX+ttOLPvbvbG91t92Ynutv+3E9lp/24nttf62E9tOm0REvYo3XSIiIiIiIqKuxBlWIiIiIiIi6kosWImIiIiIiKgrfWmzO9ArTNNEsViELMswTRPpdBqSJAnFGoaBI0eOoFwuh27XMAzoug4AWFhYwNTUlHC7TpxlWVhYWMDo6CgURQnVfjabxfj4eKh9BQBFUWCaJizLCtWmruswTROyLAMAVFUViisWi+66on0F1sZV13XEYjGYpolkMum2LRKraRri8TgqlYrvcWqVAyJ55Zc/QbnV6nWRvGoVG5RXIvneKq/8+gv455Vfu0F51So2KK/8xjUor/xig/LKb/yCcipo7KPkjMg2W70ukk8i74FeORXUZ8A7p4La9Msnv1iRfPIb11Y5FRTnl09+xz8ol9p5L/CLjZovQf0R/Z3olUtB/QVavz+J9Msrn/ziov7OIyLqSTYJURTF/bpSqdjJZFIorlAo2OVy2Y56qHO5XN3Xtf0IIkmSXS6Xbdu2bU3TbFmWQ7Xt9HtlZUU4Jp1O2wBsALaqqqFiS6WSnU6nbdteO8Zh+uu0Wfuv9ti10riO074IWZbd/SuXyy1j/XIgKK/8YoNyy+/1oLzyi/XLK5F8b5VXfrFBeeUXG5RXfrF+eSV6fJ3+i7Ypkld+4xeUU36xUXMmKJ/8Xg96nxJ5D2yVU36xfjnlFxeUT36xQe9TosfY6b9IXFA++R3/oFxq573ALzZqvgTlksjvxFa55Bcb9P7kF+uXT35xUX/nERH1IhasAiqVStOHJEmSQm0jSsFaLpfr2qlUKjYAu1KpCMWXSiX3a03TQhW7tr32gaP2w44ITdPslZWVUDGOxrZE93NlZcUuFAp1y0R/cTceE9GCtVQqNX3YCRrjxtfD5JXftsO2GyavWhWAjlZ55denoLzyihXNq6AC0LZb51VjrGheBf0hwrZb51VjrEhe+Y1fUE6Jjn2YNoO2GfS6Xz6J9tcrp4JiW+VUUJxfPvnFBuVTULutcsovTiSfWh1/kfendt4LWsW2ky9B/RHpb6v3J7/YoPcnv1i/fGoV187vPCKiXsRrWAU4p2HVisVi7mlA60VRFExNTbnfW5blti2i9jS1QqGATCYj3HaxWEQymRRev5YkSaFPUTJNE9VqFZIkwTAMWJYlfGougLq+hul7LBbD4OCge7pdIpEQinPGolGYnGBehcO8WuM3fkE5FXXs/eKCthn0ul8+ifS31biIxHrllF9cUD4FtemXT0GxrXLKL04kn1odf5H3p3beC1rFtpMvQf0Jet3vZzwo1u/9qVVsUD75tRn1vYmIqBexYBXQ6pd+tVpd97ZrfwnNzMxAVdVQH9oNw0A2m0UikUA6nRaKsSwr8jUxlmWhWCyiWCwim83CNE3hfsZiMfd6qXw+j2KxKBRb21fLslCtVoWLkkKhAACIx+MoFArCv/Sda5Vq+w+EywnmlTjmVX1OtBo/kZyKOvZ+cUHbDHrdL5/8YoNyKii2VU61ihPJp1axIvnk11+/nGoVJ5pPXsdf9P0pyntBUGw7+RLUn1avi7w/+cUGvT95xYrkk1dcO+9NREQ9abOneHtBLpezVVWtWybLctMpOX7aPdQrKyuhT8+tjU2n08L91TTN/Tpsm42n5Ileh6ppWt11QysrK5GOWTqdDtXfQqFgl0olt/0w17Dmcjn3VLBCoWADcK838tK4P2Hyyu9YBB0nv9eD8iootlVeecWJ5pVXrGheNcaGySu/ffXLK6840bzyig2TV43jFyan/MY+as4E5VNQrN/7lFesaE55xYrkVGNcmHzy29eg9ymvWJGc8ooTzafG4x82l8K8F4jGRs0XkVxqfD1MLjXGir4/NcaK5pPf/oT9nUdE1ItYsArwutZFkqS660uCtFuwptNp4Ws6vZRKJaEbKJVKpbp1whastR+EnF++Iv0ulUpN10cFFYCNnA83oiqVij02Nlb3vSRJoY6zcw2fs69+x8qrmBLNq/UqWIPyKmjbrfKqMS5MXnm1KZpXXu2K5lVQ4dFKY1yYvGrVpmheNY5fmJzyG/uoOROUT0Gv+71PNcaGySmvdkVyyqtN0Xxqta8i71ONsaI51apN0XyqPf5hf++JvheEiW0nX4J+59W+Hvb3XuO2w/zea2xXNJ+89ifs7zwiol7FU4IFtHq0ytDQ0Ia0Pzk5iWw2C1mWYVlWy1O1aum6jj179rjfO6cLiZxKOTs7i3w+j3w+D9M0MTExIXRdpWEYGBkZaVoucm1kJ05nWlxcDH1a6/DwcF0fxsfHhY4vAPcxBM5pd4qihGqfecW88iKaV17jJ5pTUcY+KC5om16vi+ZTq22L5JRXrEhOecWJ5pPfsQjKp1b9DcqpVm365ZPf8Q/KpXbeC0Riw+ZL0DaDXvfLJb/YoFzyi/XLJ5FjFPa9iYioZ212xdwrGm/v33iqVBAIzG56cU4Ds23b/au3iHK5XPcIgkKhEPrOxrZth7orcWP/CoWC8ON/bNuuexxA2Mfa2Lb3KWx+GmctbNtu+t6PJEluf9PpdOCMu1cOiOaVX/4E5ZbX66J51RgrmlciffKb3WucRRDNK692RfOqVZ+D8qoxLkxeebUpkld+4xeUUyJjHzZngrbZ6nWRfAqTq153D/aKDcopvzaD8imov3751Co2KKf82vTLp6Dj75dL7bwXBMVGyZegbYb5ndiYS36xQbkU1G6rfBLpb9jfeUREvYoFqyDnA0OhULDHxsaEi89SqWSPjY3ZANz4MG2i4TlrYYrOQqFga5pma5pmJ5PJUKe6rqys2Llczr1WSvTU3HK57F4zFab4c9pMp9O2pmmRToHO5XKhrkG17bXxcfqraVqoNjVNc4+xX7HqlwNBeeUXG5RbrV4XySu/bfvlVVCf/PLKLzYor/xig/IqqM+t8ipobPzyyi82KK+Cxs8vp4Jio+SMSH/8XvfLJ5FcbZVTQbGtcioozi+fRPrbKp9ExsYrp4LigvIp6Pj7vT+1817QKradfAn6nRf0ut/7k19s0PuTX6xfPgX1N8rvPCKiXtRn27YtNhdLREREREREtHF4DSsRERERERF1JRasRERERERE1JVYsBIREREREVFXYsFKREREREREXYkFKxEREREREXUlFqxERERERETUlViwEhERERERUVdiwUpEPU3XdcTjcUxOTiKfz2NwcBCDg4PI5/PIZrOIx+MwDCMwvlgsbmCv2zc4OBjYZ5F1iIiIiLrZlza7A0RE7bAsC6VSCbIsAwBKpRJisRjS6TQAYHR0FKZpQlEUz3hVVaGq6ob1t1NyuRyGhobqllmWBUmSfNchIiIi6iWcYSWinlatVt1i1YuiKKhWq77bqC3yeoWqqnX9Nk0Ts7OzvusQERER9RoWrETU05566qmOrNPrcrncZneBiIiIqON4SjAR9TSRGURJkmAYBnRdhyzLME0TyWTSc2Y2k8lA13Xkcjk3TpZlLCwsIJfLQdd1ZLNZZDIZd1ulUgmFQqFl+7quI5PJQFVVJBIJVKtVlMtltw0ALftnWRZmZ2fdrxcWFjA6OoojR44gk8kgnU5D13UsLi66M8mqqsKyrLp1/NqIsk9EREREG4EFKxHd8UzTRDabRalUcpcNDg5ifn6+ruC1LAvxeByapsE0TaRSKZTLZQBrpx5PTk5ibGwMqqrWFXSFQgGGYfheJ5tMJtHf349kMgkAKBaLSKVSKJVKvv3L5/NQFMW9zrZarUJRFIyOjtZtX1VVxONxtzgFULeOXxtOfJh9IiIiItoIPCWYiO54mqY1FV6yLNdd87mwsICRkRG34NM0DbFYDLquQ9d1dx0A6O/vx/DwsBsrSVLgdbLOeo5kMgld12FZlm//kskkUqkUBgcHMTk5Gfn05qBjEHWfiIiIiNYTC1YiIqwVbLlcDqlUyl3mzGyqqop0Or0pp8jGYjGsrKxgamoKy8vLdf1rxbKs9e8YERER0QZgwUpEd7zR0VF3ltRhGEbdbKUsy1BVFbIsY3Jy0jOm8fuwagvJYrHo3sXXr38TExPuY3lqr3lt3F6rfjrriBwDIiIiom7Da1iJ6I6g6zpM04RhGACAfD6PoaEhKIriFnuTk5PuDZQKhQIkSXJP+XWu14zH48hmsxgbG0Mul0M2m3VPlVVVFYZhYGZmxv3eaVPTNMiy7PuInUql4p4G7PQBgG//+vv7oes6YrEYqtUqRkdH3T7EYjH3xkmZTAa5XA75fL6un846fm20s09ERERE66nPtm17sztBRHSny2azTTdFIiIiIiJ/PCWYiIiIiIiIuhILViKideacduw8KoaIiIiIxPCUYCIiIiIiIupKnGElIiIiIiKirsSClYiIiIiIiLoSC1YiIiIiIiLqSixYiYiIiIiIqCuxYCUiIiIiIqKuxIKViIiIiIiIuhILViIiIiIiIupKLFiJiIiIiIioK7FgJSIiIiIioq70/wPpkCs87M4HsQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 650x155 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def diff_mask_tensor(A, B):\n",
    "    A = A.to(dtype=torch.int64)\n",
    "    B = B.to(dtype=torch.int64)\n",
    "    matcher = difflib.SequenceMatcher(None, A.tolist(), B.tolist(), autojunk=False)\n",
    "    mask = []\n",
    "    for tag, i1, i2, j1, j2 in matcher.get_opcodes():\n",
    "        if tag == 'equal':\n",
    "            mask.extend([0] * (j2 - j1))\n",
    "        else:\n",
    "            mask.extend([1] * (j2 - j1))\n",
    "    return torch.tensor(mask, dtype=torch.int64)\n",
    "def generate_then_edit_meaningful(\n",
    "        model_name, pattern_name, data_idx,\n",
    "        delta=5.8, tolerance=(-1,+1), token_count=64):\n",
    "    pattern = PATTERNS[pattern_name]\n",
    "    window = len(pattern['pattern'])\n",
    "    data_before = {\n",
    "        \"config\": {\n",
    "            \"verbose\": False,\n",
    "            \"data.file_name\": \"01_wikitext2.json\",\n",
    "            \"data.lines\": (data_idx, data_idx+1),\n",
    "            \"model.name\": model_name,\n",
    "            \"tokenizer.truncation\": True,\n",
    "            \"tokenizer.truncation_side\": \"right\",\n",
    "            \"tokenizer.padding_side\": \"left\",\n",
    "            \"tokenizer.output_actual_prefixes_text\": True,\n",
    "            \"tokenizer.max_length\": 10,\n",
    "            \"model.token_count\": token_count,\n",
    "            \"model.do_sample\": True,\n",
    "            \"model.num_beams\": 32,\n",
    "            \"model.temperature\": 1,\n",
    "            \"model.output_scores\": False,\n",
    "            \"watermark.delta\": delta,\n",
    "            \"watermark.colors\": pattern['colors'],\n",
    "            \"watermark.color_pattern\": pattern['pattern'],\n",
    "            \"detection.window\": window,\n",
    "            \"edit_detection.window\": window,\n",
    "            \"watermark.fn_pattern\": fn_pattern_using_prev,\n",
    "            \"watermark.fn_colors\": pattern['fn_colors'],\n",
    "            \"detection.threshold\": pattern['thresh'],\n",
    "            \"edit_detection.threshold\": pattern['thresh'],\n",
    "            \"edit_detection.tolerance\": tolerance,\n",
    "        },\n",
    "    }\n",
    "    # 1. generate\n",
    "    data_before = steps_reduce([\n",
    "        step_model_load, step_prefixes_load, step_tokenize,\n",
    "        step_generate_watermarked, step_decode,], data_before)\n",
    "    cache_clear(data_before)\n",
    "    # 2. edit\n",
    "    data_after = copy.deepcopy(data_before)\n",
    "    suffix_modified = None\n",
    "    while suffix_modified is None:\n",
    "        try:\n",
    "            suffix = data_before['suffixes_text'][0]\n",
    "            suffix_modified = [apply_meaningful_edit(suffix, gemini_api_key=\"INSERT_GEMINI_API_KEY_HERE\")]\n",
    "        except Exception as e:\n",
    "            print(e)\n",
    "            import time\n",
    "            time.sleep(10)\n",
    "            print(\"Retying Gemini...\")\n",
    "            pass\n",
    "    data_after['suffixes_text'] = suffix_modified\n",
    "    tokenizer = tokenizer = AutoTokenizer.from_pretrained(\n",
    "        data_after['config']['model.name'])\n",
    "    if tokenizer.pad_token is None:\n",
    "        tokenizer.pad_token = tokenizer.decode([2])\n",
    "    suf_tokd = tokenizer(\n",
    "        [data_after[\"prefixes_text_actual\"][0] + data_after[\"suffixes_text\"][0]],\n",
    "        return_tensors=\"pt\", add_special_tokens=True,\n",
    "        ).to(data_after[\"device\"])\n",
    "    prefix_len = data_after['prefixes_tokd']['input_ids'].size(1)\n",
    "    data_after['suffixes_tokd'] = suf_tokd['input_ids'][:, prefix_len:]\n",
    "    data_after['edits.mask'] = torch.stack([diff_mask_tensor(\n",
    "        data_before['suffixes_tokd'][0], data_after['suffixes_tokd'][0])])\n",
    "    data_after['edits.mask'][0][0] = 0\n",
    "    data_after['edits.mask'][0][1] = 0\n",
    "    data_after['edits.mask'][0][-1] = 0\n",
    "    data_after['edits.mask'][0][-2] = 0\n",
    "    data_after['edits.positions'] = torch.tensor(\n",
    "        [[i for i, v in enumerate(data_after['edits.mask'][0]) if v]])\n",
    "    # 3. evalute\n",
    "    data_after = steps_reduce(\n",
    "        [step_score_edit, step_eval_edit_detection_with_tolerance,], data_after)\n",
    "    return data_before, data_after\n",
    "\n",
    "random.seed(42)\n",
    "np.random.seed(42)\n",
    "torch.manual_seed(42)\n",
    "for data_idx, pattern_name in [\n",
    "    (1, \"AB\"),\n",
    "    (6, \"ACADBCBD\"),\n",
    "]:\n",
    "    before, after = generate_then_edit_meaningful(\n",
    "        model_name=MODEL_NAME, pattern_name=pattern_name,\n",
    "        data_idx=data_idx, token_count=TOKEN_COUNT)\n",
    "    print(f\"MEANINGFUL_EDIT on {pattern_name}\")\n",
    "    print(f\"  PROMPT: {before['prefixes_text_actual'][0]}...\")\n",
    "    for idx, diff in enumerate(inline_diff_color(before['suffixes_text'][0], after['suffixes_text'][0])):\n",
    "        print(\"  \" + (\"LLM:\" if idx == 0 else \"Edited:\") + \" ...\" + diff)\n",
    "    plt.figure(figsize=(6.5, 1.55))\n",
    "    plot_edit_score(after, 0, tok_count=TOKEN_COUNT)\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c0667b2e",
   "metadata": {},
   "source": [
    "# Figure 5, 7, and 8: Edit detection accuracy under different edit lengths "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "bca2589a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Namespace(model='meta-llama/Llama-2-7b-hf', delta=4.8, batch_idx=1, edits_count=7) 15_Llama-2-7b-hf_randACADBCBD_delta=4.8_w=8_1.pkl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loading checkpoint shards: 100%|██████████| 2/2 [00:14<00:00,  6.74s/it]g checkpoint shards: 100%|██████████| 2/2 [00:14<00:00,  7.38s/it]\n",
      "batch_idx=1 DONE: 100%|█████████▌| 20/21 [03:58<00:11, 11.30s/it]      1<03:44, 11.25s/it]        | 2/21 [00:22<03:29, 11.01s/it], 11.01s/it]▍        | 3/21 [00:33<03:17, 10.97s/it]3:17, 10.97s/it]�▉        | 4/21 [00:44<03:10, 11.21s/it]03:10, 11.21s/it]�█▍       | 5/21 [00:55<02:59, 11.25s/it]0:55<02:59, 11.25s/it]|██▊       | 6/21 [01:07<02:50, 11.37s/it][01:07<02:50, 11.37s/it]███▎      | 7/21 [01:19<02:40, 11.46s/it]21 [01:19<02:40, 11.46s/it]%|███▊      | 8/21 [01:30<02:27, 11.32s/it] 8/21 [01:30<02:27, 11.32s/it]3%|████▎     | 9/21 [01:41<02:15, 11.28s/it]   | 9/21 [01:41<02:15, 11.28s/it]48%|████▊     | 10/21 [01:53<02:06, 11.48s/it]     | 10/21 [01:53<02:06, 11.48s/it] 52%|█████▏    | 11/21 [02:04<01:53, 11.32s/it]�█▏    | 11/21 [02:04<01:53, 11.32s/it]E:  57%|█████▋    | 12/21 [02:15<01:41, 11.31s/it]██▋    | 12/21 [02:15<01:41, 11.31s/it]:  62%|██████▏   | 13/21 [02:27<01:31, 11.50s/it]NE:  67%|██████▋   | 14/21 [02:38<01:19, 11.33s/it]�████▋   | 14/21 [02:38<01:19, 11.33s/it]ONE:  71%|███████▏  | 15/21 [02:49<01:08, 11.35s/it]██████▏  | 15/21 [02:49<01:08, 11.35s/it]DONE:  76%|███████▌  | 16/21 [03:01<00:57, 11.57s/it]�██████▌  | 16/21 [03:01<00:57, 11.57s/it]DONE:  81%|████████  | 17/21 [03:12<00:45, 11.27s/it]��███████  | 17/21 [03:12<00:45, 11.27s/it] DONE:  86%|████████▌ | 18/21 [03:23<00:33, 11.30s/it]|████████▌ | 18/21 [03:23<00:33, 11.30s/it]1 DONE:  90%|█████████ | 19/21 [03:36<00:23, 11.63s/it]%|█████████ | 19/21 [03:36<00:23, 11.63s/it]1 DONE:  95%|█████████▌| 20/21 [03:46<00:11, 11.30s/it] 95%|█████████▌| 20/21 [03:46<00:11, 11.30s/it]dx=1 DONE: 100%|██████████| 21/21 [03:58<00:00, 11.32s/it]%|██████████| 21/21 [03:58<00:00, 11.34s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "    batch_idx edits.type  ...  base.ppl  watermark.delta\n",
      "0           1     INSERT  ...  7.848106              4.8\n",
      "3           1     INSERT  ...  7.848106              4.8\n",
      "6           1     INSERT  ...  7.848106              4.8\n",
      "9           1     INSERT  ...  7.848106              4.8\n",
      "12          1     INSERT  ...  7.848106              4.8\n",
      "15          1     INSERT  ...  7.848106              4.8\n",
      "18          1     INSERT  ...  7.848106              4.8\n",
      "1           1     REMOVE  ...  7.848106              4.8\n",
      "4           1     REMOVE  ...  7.848106              4.8\n",
      "7           1     REMOVE  ...  7.848106              4.8\n",
      "10          1     REMOVE  ...  7.848106              4.8\n",
      "13          1     REMOVE  ...  7.848106              4.8\n",
      "16          1     REMOVE  ...  7.848106              4.8\n",
      "19          1     REMOVE  ...  7.848106              4.8\n",
      "2           1    REPLACE  ...  7.848106              4.8\n",
      "5           1    REPLACE  ...  7.848106              4.8\n",
      "8           1    REPLACE  ...  7.848106              4.8\n",
      "11          1    REPLACE  ...  7.848106              4.8\n",
      "14          1    REPLACE  ...  7.848106              4.8\n",
      "17          1    REPLACE  ...  7.848106              4.8\n",
      "20          1    REPLACE  ...  7.848106              4.8\n",
      "\n",
      "[21 rows x 14 columns]\n",
      "Namespace(model='meta-llama/Llama-2-7b-hf', delta=4.8, batch_idx=1, edits_count=7) 15_Llama-2-7b-hf_randAB_delta=4.8_w=2_1.pkl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "batch_idx=1 DONE: 100%|█████████▌| 20/21 [01:54<00:05,  5.40s/it]      5<01:55,  5.77s/it]]        | 2/21 [00:11<01:44,  5.52s/it],  5.52s/it]▍        | 3/21 [00:16<01:37,  5.44s/it]1:37,  5.44s/it]�▉        | 4/21 [00:21<01:32,  5.43s/it]01:32,  5.43s/it]�█▍       | 5/21 [00:27<01:26,  5.38s/it]0:27<01:26,  5.38s/it]|██▊       | 6/21 [00:32<01:20,  5.39s/it][00:32<01:20,  5.39s/it]███▎      | 7/21 [00:38<01:17,  5.51s/it]21 [00:38<01:17,  5.51s/it]%|███▊      | 8/21 [00:43<01:10,  5.44s/it] 8/21 [00:43<01:10,  5.44s/it]3%|████▎     | 9/21 [00:49<01:05,  5.44s/it]   | 9/21 [00:49<01:05,  5.44s/it]48%|████▊     | 10/21 [00:54<01:00,  5.52s/it]     | 10/21 [00:54<01:00,  5.52s/it] 52%|█████▏    | 11/21 [01:00<00:54,  5.44s/it]�█▏    | 11/21 [01:00<00:54,  5.44s/it]E:  57%|█████▋    | 12/21 [01:05<00:49,  5.48s/it]██▋    | 12/21 [01:05<00:49,  5.48s/it]:  62%|██████▏   | 13/21 [01:11<00:44,  5.56s/it]�███▏   | 13/21 [01:11<00:44,  5.56s/it]NE:  67%|██████▋   | 14/21 [01:16<00:38,  5.44s/it]�████▋   | 14/21 [01:16<00:38,  5.44s/it]ONE:  71%|███████▏  | 15/21 [01:21<00:32,  5.42s/it]██████▏  | 15/21 [01:21<00:32,  5.42s/it]DONE:  76%|███████▌  | 16/21 [01:27<00:27,  5.51s/it]�██████▌  | 16/21 [01:27<00:27,  5.51s/it]DONE:  81%|████████  | 17/21 [01:32<00:21,  5.41s/it]��███████  | 17/21 [01:32<00:21,  5.41s/it] DONE:  86%|████████▌ | 18/21 [01:38<00:16,  5.43s/it]|████████▌ | 18/21 [01:38<00:16,  5.43s/it]1 DONE:  90%|█████████ | 19/21 [01:44<00:11,  5.54s/it]%|█████████ | 19/21 [01:44<00:11,  5.54s/it]1 DONE:  95%|█████████▌| 20/21 [01:49<00:05,  5.40s/it] 95%|█████████▌| 20/21 [01:49<00:05,  5.40s/it]dx=1 DONE: 100%|██████████| 21/21 [01:54<00:00,  5.46s/it]%|██████████| 21/21 [01:54<00:00,  5.46s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "    batch_idx edits.type  ...  base.ppl  watermark.delta\n",
      "0           1     INSERT  ...  4.299192              4.8\n",
      "3           1     INSERT  ...  4.299192              4.8\n",
      "6           1     INSERT  ...  4.299192              4.8\n",
      "9           1     INSERT  ...  4.299192              4.8\n",
      "12          1     INSERT  ...  4.299192              4.8\n",
      "15          1     INSERT  ...  4.299192              4.8\n",
      "18          1     INSERT  ...  4.299192              4.8\n",
      "1           1     REMOVE  ...  4.299192              4.8\n",
      "4           1     REMOVE  ...  4.299192              4.8\n",
      "7           1     REMOVE  ...  4.299192              4.8\n",
      "10          1     REMOVE  ...  4.299192              4.8\n",
      "13          1     REMOVE  ...  4.299192              4.8\n",
      "16          1     REMOVE  ...  4.299192              4.8\n",
      "19          1     REMOVE  ...  4.299192              4.8\n",
      "2           1    REPLACE  ...  4.299192              4.8\n",
      "5           1    REPLACE  ...  4.299192              4.8\n",
      "8           1    REPLACE  ...  4.299192              4.8\n",
      "11          1    REPLACE  ...  4.299192              4.8\n",
      "14          1    REPLACE  ...  4.299192              4.8\n",
      "17          1    REPLACE  ...  4.299192              4.8\n",
      "20          1    REPLACE  ...  4.299192              4.8\n",
      "\n",
      "[21 rows x 14 columns]\n",
      "Namespace(model='meta-llama/Llama-2-7b-hf', delta=4.8, batch_idx=1, edits_count=7) 15_Llama-2-7b-hf_randAA_delta=4.8_w=2_1.pkl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "batch_idx=1 DONE: 100%|█████████▌| 20/21 [01:55<00:05,  5.48s/it]      5<01:57,  5.89s/it]]        | 2/21 [00:11<01:46,  5.59s/it],  5.59s/it]▍        | 3/21 [00:16<01:38,  5.47s/it]1:38,  5.47s/it]�▉        | 4/21 [00:22<01:32,  5.46s/it]01:32,  5.46s/it]�█▍       | 5/21 [00:27<01:26,  5.40s/it]0:27<01:26,  5.40s/it]|██▊       | 6/21 [00:32<01:20,  5.39s/it][00:32<01:20,  5.39s/it]███▎      | 7/21 [00:38<01:15,  5.42s/it]21 [00:38<01:15,  5.42s/it]%|███▊      | 8/21 [00:43<01:10,  5.39s/it] 8/21 [00:43<01:10,  5.39s/it]3%|████▎     | 9/21 [00:48<01:04,  5.41s/it]   | 9/21 [00:48<01:04,  5.41s/it]48%|████▊     | 10/21 [00:54<01:00,  5.49s/it]     | 10/21 [00:54<01:00,  5.49s/it] 52%|█████▏    | 11/21 [00:59<00:54,  5.40s/it]�█▏    | 11/21 [00:59<00:54,  5.40s/it]E:  57%|█████▋    | 12/21 [01:05<00:49,  5.54s/it]██▋    | 12/21 [01:05<00:49,  5.54s/it]:  62%|██████▏   | 13/21 [01:11<00:44,  5.61s/it]�███▏   | 13/21 [01:11<00:44,  5.61s/it]NE:  67%|██████▋   | 14/21 [01:16<00:38,  5.50s/it]�████▋   | 14/21 [01:16<00:38,  5.50s/it]ONE:  71%|███████▏  | 15/21 [01:22<00:33,  5.51s/it]██████▏  | 15/21 [01:22<00:33,  5.51s/it]DONE:  76%|███████▌  | 16/21 [01:28<00:28,  5.61s/it]�██████▌  | 16/21 [01:28<00:28,  5.61s/it]DONE:  81%|████████  | 17/21 [01:33<00:21,  5.50s/it]��███████  | 17/21 [01:33<00:21,  5.50s/it] DONE:  86%|████████▌ | 18/21 [01:38<00:16,  5.53s/it]|████████▌ | 18/21 [01:38<00:16,  5.53s/it]1 DONE:  90%|█████████ | 19/21 [01:44<00:11,  5.62s/it]1 DONE:  95%|█████████▌| 20/21 [01:49<00:05,  5.48s/it] 95%|█████████▌| 20/21 [01:49<00:05,  5.48s/it]dx=1 DONE: 100%|██████████| 21/21 [01:55<00:00,  5.60s/it]%|██████████| 21/21 [01:55<00:00,  5.51s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "    batch_idx edits.type  ...  base.ppl  watermark.delta\n",
      "0           1     INSERT  ...  4.113686              4.8\n",
      "3           1     INSERT  ...  4.113686              4.8\n",
      "6           1     INSERT  ...  4.113686              4.8\n",
      "9           1     INSERT  ...  4.113686              4.8\n",
      "12          1     INSERT  ...  4.113686              4.8\n",
      "15          1     INSERT  ...  4.113686              4.8\n",
      "18          1     INSERT  ...  4.113686              4.8\n",
      "1           1     REMOVE  ...  4.113686              4.8\n",
      "4           1     REMOVE  ...  4.113686              4.8\n",
      "7           1     REMOVE  ...  4.113686              4.8\n",
      "10          1     REMOVE  ...  4.113686              4.8\n",
      "13          1     REMOVE  ...  4.113686              4.8\n",
      "16          1     REMOVE  ...  4.113686              4.8\n",
      "19          1     REMOVE  ...  4.113686              4.8\n",
      "2           1    REPLACE  ...  4.113686              4.8\n",
      "5           1    REPLACE  ...  4.113686              4.8\n",
      "8           1    REPLACE  ...  4.113686              4.8\n",
      "11          1    REPLACE  ...  4.113686              4.8\n",
      "14          1    REPLACE  ...  4.113686              4.8\n",
      "17          1    REPLACE  ...  4.113686              4.8\n",
      "20          1    REPLACE  ...  4.113686              4.8\n",
      "\n",
      "[21 rows x 14 columns]\n",
      "Namespace(model='meta-llama/Llama-2-7b-hf', delta=4.8, batch_idx=1, edits_count=7) 15_Llama-2-7b-hf_fixedAA (fixed)_delta=4.8_w=2_1.pkl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "batch_idx=1 DONE: 100%|██████████| 21/21 [01:47<00:00,  5.10s/it]      5<01:40,  5.03s/it]]        | 2/21 [00:09<01:31,  4.83s/it],  4.83s/it]▍        | 3/21 [00:14<01:25,  4.76s/it]1:25,  4.76s/it]�▉        | 4/21 [00:19<01:21,  4.82s/it]01:21,  4.82s/it]�█▍       | 5/21 [00:23<01:16,  4.75s/it]|██▊       | 6/21 [00:28<01:11,  4.74s/it][00:28<01:11,  4.74s/it]███▎      | 7/21 [00:33<01:06,  4.76s/it]21 [00:33<01:06,  4.76s/it]%|███▊      | 8/21 [00:38<01:01,  4.77s/it] 8/21 [00:38<01:01,  4.77s/it]3%|████▎     | 9/21 [00:42<00:56,  4.75s/it]48%|████▊     | 10/21 [00:47<00:52,  4.82s/it]     | 10/21 [00:47<00:52,  4.82s/it] 52%|█████▏    | 11/21 [00:52<00:47,  4.73s/it]�█▏    | 11/21 [00:52<00:47,  4.73s/it]E:  57%|█████▋    | 12/21 [00:57<00:42,  4.73s/it]██▋    | 12/21 [00:57<00:42,  4.73s/it]:  62%|██████▏   | 13/21 [01:02<00:38,  4.87s/it]�███▏   | 13/21 [01:02<00:38,  4.87s/it]NE:  67%|██████▋   | 14/21 [01:06<00:33,  4.78s/it]�████▋   | 14/21 [01:06<00:33,  4.78s/it]ONE:  71%|███████▏  | 15/21 [01:11<00:28,  4.80s/it]██████▏  | 15/21 [01:11<00:28,  4.80s/it]DONE:  76%|███████▌  | 16/21 [01:18<00:27,  5.48s/it]�██████▌  | 16/21 [01:18<00:27,  5.48s/it]DONE:  81%|████████  | 17/21 [01:25<00:23,  5.76s/it]��███████  | 17/21 [01:25<00:23,  5.76s/it] DONE:  86%|████████▌ | 18/21 [01:32<00:18,  6.10s/it]|████████▌ | 18/21 [01:32<00:18,  6.10s/it]1 DONE:  90%|█████████ | 19/21 [01:37<00:11,  5.90s/it]%|█████████ | 19/21 [01:37<00:11,  5.90s/it]1 DONE:  95%|█████████▌| 20/21 [01:42<00:05,  5.54s/it] 95%|█████████▌| 20/21 [01:42<00:05,  5.54s/it]dx=1 DONE: 100%|██████████| 21/21 [01:47<00:00,  5.34s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "    batch_idx edits.type  ...  base.ppl  watermark.delta\n",
      "0           1     INSERT  ...  4.006683              4.8\n",
      "3           1     INSERT  ...  4.006683              4.8\n",
      "6           1     INSERT  ...  4.006683              4.8\n",
      "9           1     INSERT  ...  4.006683              4.8\n",
      "12          1     INSERT  ...  4.006683              4.8\n",
      "15          1     INSERT  ...  4.006683              4.8\n",
      "18          1     INSERT  ...  4.006683              4.8\n",
      "1           1     REMOVE  ...  4.006683              4.8\n",
      "4           1     REMOVE  ...  4.006683              4.8\n",
      "7           1     REMOVE  ...  4.006683              4.8\n",
      "10          1     REMOVE  ...  4.006683              4.8\n",
      "13          1     REMOVE  ...  4.006683              4.8\n",
      "16          1     REMOVE  ...  4.006683              4.8\n",
      "19          1     REMOVE  ...  4.006683              4.8\n",
      "2           1    REPLACE  ...  4.006683              4.8\n",
      "5           1    REPLACE  ...  4.006683              4.8\n",
      "8           1    REPLACE  ...  4.006683              4.8\n",
      "11          1    REPLACE  ...  4.006683              4.8\n",
      "14          1    REPLACE  ...  4.006683              4.8\n",
      "17          1    REPLACE  ...  4.006683              4.8\n",
      "20          1    REPLACE  ...  4.006683              4.8\n",
      "\n",
      "[21 rows x 14 columns]\n",
      "Namespace(model='meta-llama/Llama-2-7b-hf', delta=4.8, batch_idx=1, edits_count=7) 15_Llama-2-7b-hf_randACBC_delta=4.8_w=4_1.pkl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "batch_idx=1 DONE: 100%|██████████| 21/21 [02:30<00:00,  7.17s/it]      7<02:27,  7.38s/it]]        | 2/21 [00:14<02:16,  7.18s/it]▍        | 3/21 [00:21<02:07,  7.10s/it]2:07,  7.10s/it]�▉        | 4/21 [00:28<02:02,  7.18s/it]02:02,  7.18s/it]�█▍       | 5/21 [00:35<01:53,  7.12s/it]0:35<01:53,  7.12s/it]|██▊       | 6/21 [00:42<01:46,  7.12s/it][00:42<01:46,  7.12s/it]███▎      | 7/21 [00:50<01:40,  7.18s/it]21 [00:50<01:40,  7.18s/it]%|███▊      | 8/21 [00:57<01:32,  7.11s/it] 8/21 [00:57<01:32,  7.11s/it]3%|████▎     | 9/21 [01:04<01:26,  7.24s/it]   | 9/21 [01:04<01:26,  7.24s/it]48%|████▊     | 10/21 [01:12<01:20,  7.32s/it]     | 10/21 [01:12<01:20,  7.32s/it] 52%|█████▏    | 11/21 [01:19<01:12,  7.20s/it]�█▏    | 11/21 [01:19<01:12,  7.20s/it]E:  57%|█████▋    | 12/21 [01:26<01:04,  7.18s/it]██▋    | 12/21 [01:26<01:04,  7.18s/it]:  62%|██████▏   | 13/21 [01:33<00:58,  7.28s/it]�███▏   | 13/21 [01:33<00:58,  7.28s/it]NE:  67%|██████▋   | 14/21 [01:40<00:49,  7.10s/it]�████▋   | 14/21 [01:40<00:49,  7.10s/it]ONE:  71%|███████▏  | 15/21 [01:47<00:42,  7.12s/it]██████▏  | 15/21 [01:47<00:42,  7.12s/it]DONE:  76%|███████▌  | 16/21 [01:55<00:36,  7.26s/it]�██████▌  | 16/21 [01:55<00:36,  7.26s/it]DONE:  81%|████████  | 17/21 [02:01<00:28,  7.09s/it]��███████  | 17/21 [02:01<00:28,  7.09s/it] DONE:  86%|████████▌ | 18/21 [02:09<00:21,  7.12s/it]|████████▌ | 18/21 [02:09<00:21,  7.12s/it]1 DONE:  90%|█████████ | 19/21 [02:16<00:14,  7.28s/it]%|█████████ | 19/21 [02:16<00:14,  7.28s/it]1 DONE:  95%|█████████▌| 20/21 [02:23<00:07,  7.08s/it]dx=1 DONE: 100%|██████████| 21/21 [02:30<00:00,  7.12s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "    batch_idx edits.type  ...  base.ppl  watermark.delta\n",
      "0           1     INSERT  ...  6.165144              4.8\n",
      "3           1     INSERT  ...  6.165144              4.8\n",
      "6           1     INSERT  ...  6.165144              4.8\n",
      "9           1     INSERT  ...  6.165144              4.8\n",
      "12          1     INSERT  ...  6.165144              4.8\n",
      "15          1     INSERT  ...  6.165144              4.8\n",
      "18          1     INSERT  ...  6.165144              4.8\n",
      "1           1     REMOVE  ...  6.165144              4.8\n",
      "4           1     REMOVE  ...  6.165144              4.8\n",
      "7           1     REMOVE  ...  6.165144              4.8\n",
      "10          1     REMOVE  ...  6.165144              4.8\n",
      "13          1     REMOVE  ...  6.165144              4.8\n",
      "16          1     REMOVE  ...  6.165144              4.8\n",
      "19          1     REMOVE  ...  6.165144              4.8\n",
      "2           1    REPLACE  ...  6.165144              4.8\n",
      "5           1    REPLACE  ...  6.165144              4.8\n",
      "8           1    REPLACE  ...  6.165144              4.8\n",
      "11          1    REPLACE  ...  6.165144              4.8\n",
      "14          1    REPLACE  ...  6.165144              4.8\n",
      "17          1    REPLACE  ...  6.165144              4.8\n",
      "20          1    REPLACE  ...  6.165144              4.8\n",
      "\n",
      "[21 rows x 14 columns]\n",
      "Namespace(model='meta-llama/Llama-2-7b-hf', delta=5.8, batch_idx=1, edits_count=7) 15_Llama-2-7b-hf_randACADBCBD_delta=5.8_w=8_1.pkl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loading checkpoint shards: 100%|██████████| 2/2 [00:14<00:00,  6.72s/it]g checkpoint shards: 100%|██████████| 2/2 [00:14<00:00,  7.37s/it]\n",
      "batch_idx=1 DONE: 100%|█████████▌| 20/21 [03:40<00:10, 10.50s/it]      0<03:26, 10.33s/it]]        | 2/21 [00:20<03:14, 10.21s/it], 10.21s/it]▍        | 3/21 [00:30<03:01, 10.08s/it]3:01, 10.08s/it]�▉        | 4/21 [00:41<02:55, 10.29s/it]02:55, 10.29s/it]�█▍       | 5/21 [00:51<02:45, 10.37s/it]0:51<02:45, 10.37s/it]|██▊       | 6/21 [01:01<02:36, 10.41s/it][01:01<02:36, 10.41s/it]███▎      | 7/21 [01:12<02:27, 10.53s/it]21 [01:12<02:27, 10.53s/it]%|███▊      | 8/21 [01:23<02:16, 10.48s/it] 8/21 [01:23<02:16, 10.48s/it]3%|████▎     | 9/21 [01:33<02:06, 10.51s/it]   | 9/21 [01:33<02:06, 10.51s/it]48%|████▊     | 10/21 [01:44<01:57, 10.66s/it]     | 10/21 [01:44<01:57, 10.66s/it] 52%|█████▏    | 11/21 [01:54<01:45, 10.53s/it]�█▏    | 11/21 [01:54<01:45, 10.53s/it]E:  57%|█████▋    | 12/21 [02:05<01:35, 10.57s/it]:  62%|██████▏   | 13/21 [02:16<01:26, 10.78s/it]�███▏   | 13/21 [02:16<01:26, 10.78s/it]NE:  67%|██████▋   | 14/21 [02:26<01:13, 10.52s/it]ONE:  71%|███████▏  | 15/21 [02:37<01:03, 10.51s/it]██████▏  | 15/21 [02:37<01:03, 10.51s/it]DONE:  76%|███████▌  | 16/21 [02:48<00:53, 10.73s/it]�██████▌  | 16/21 [02:48<00:53, 10.73s/it]DONE:  81%|████████  | 17/21 [02:58<00:41, 10.49s/it]��███████  | 17/21 [02:58<00:41, 10.49s/it] DONE:  86%|████████▌ | 18/21 [03:09<00:31, 10.52s/it]|████████▌ | 18/21 [03:09<00:31, 10.52s/it]1 DONE:  90%|█████████ | 19/21 [03:20<00:21, 10.79s/it]%|█████████ | 19/21 [03:20<00:21, 10.79s/it]1 DONE:  95%|█████████▌| 20/21 [03:30<00:10, 10.50s/it] 95%|█████████▌| 20/21 [03:30<00:10, 10.50s/it]dx=1 DONE: 100%|██████████| 21/21 [03:40<00:00, 10.50s/it]%|██████████| 21/21 [03:40<00:00, 10.51s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "    batch_idx edits.type  ...  base.ppl  watermark.delta\n",
      "0           1     INSERT  ...  9.562543              5.8\n",
      "3           1     INSERT  ...  9.562543              5.8\n",
      "6           1     INSERT  ...  9.562543              5.8\n",
      "9           1     INSERT  ...  9.562543              5.8\n",
      "12          1     INSERT  ...  9.562543              5.8\n",
      "15          1     INSERT  ...  9.562543              5.8\n",
      "18          1     INSERT  ...  9.562543              5.8\n",
      "1           1     REMOVE  ...  9.562543              5.8\n",
      "4           1     REMOVE  ...  9.562543              5.8\n",
      "7           1     REMOVE  ...  9.562543              5.8\n",
      "10          1     REMOVE  ...  9.562543              5.8\n",
      "13          1     REMOVE  ...  9.562543              5.8\n",
      "16          1     REMOVE  ...  9.562543              5.8\n",
      "19          1     REMOVE  ...  9.562543              5.8\n",
      "2           1    REPLACE  ...  9.562543              5.8\n",
      "5           1    REPLACE  ...  9.562543              5.8\n",
      "8           1    REPLACE  ...  9.562543              5.8\n",
      "11          1    REPLACE  ...  9.562543              5.8\n",
      "14          1    REPLACE  ...  9.562543              5.8\n",
      "17          1    REPLACE  ...  9.562543              5.8\n",
      "20          1    REPLACE  ...  9.562543              5.8\n",
      "\n",
      "[21 rows x 14 columns]\n",
      "Namespace(model='meta-llama/Llama-2-7b-hf', delta=5.8, batch_idx=1, edits_count=7) 15_Llama-2-7b-hf_randAB_delta=5.8_w=2_1.pkl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "batch_idx=1 DONE: 100%|██████████| 21/21 [01:53<00:00,  5.39s/it]      5<01:54,  5.70s/it]        | 2/21 [00:11<01:44,  5.51s/it],  5.51s/it]▍        | 3/21 [00:16<01:38,  5.48s/it]1:38,  5.48s/it]�▉        | 4/21 [00:22<01:33,  5.48s/it]01:33,  5.48s/it]�█▍       | 5/21 [00:27<01:26,  5.42s/it]|██▊       | 6/21 [00:32<01:21,  5.41s/it]███▎      | 7/21 [00:38<01:15,  5.42s/it]21 [00:38<01:15,  5.42s/it]%|███▊      | 8/21 [00:43<01:09,  5.35s/it] 8/21 [00:43<01:09,  5.35s/it]3%|████▎     | 9/21 [00:48<01:04,  5.37s/it]   | 9/21 [00:48<01:04,  5.37s/it]48%|████▊     | 10/21 [00:54<00:59,  5.42s/it]     | 10/21 [00:54<00:59,  5.42s/it] 52%|█████▏    | 11/21 [00:59<00:53,  5.37s/it]�█▏    | 11/21 [00:59<00:53,  5.37s/it]E:  57%|█████▋    | 12/21 [01:04<00:48,  5.38s/it]:  62%|██████▏   | 13/21 [01:10<00:43,  5.43s/it]NE:  67%|██████▋   | 14/21 [01:15<00:37,  5.36s/it]�████▋   | 14/21 [01:15<00:37,  5.36s/it]ONE:  71%|███████▏  | 15/21 [01:21<00:32,  5.37s/it]██████▏  | 15/21 [01:21<00:32,  5.37s/it]DONE:  76%|███████▌  | 16/21 [01:26<00:27,  5.45s/it]DONE:  81%|████████  | 17/21 [01:31<00:21,  5.35s/it] DONE:  86%|████████▌ | 18/21 [01:37<00:16,  5.34s/it]|████████▌ | 18/21 [01:37<00:16,  5.34s/it]1 DONE:  90%|█████████ | 19/21 [01:42<00:10,  5.42s/it]%|█████████ | 19/21 [01:42<00:10,  5.42s/it]1 DONE:  95%|█████████▌| 20/21 [01:47<00:05,  5.29s/it] 95%|█████████▌| 20/21 [01:47<00:05,  5.29s/it]dx=1 DONE: 100%|██████████| 21/21 [01:53<00:00,  5.31s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "    batch_idx edits.type  ...  base.ppl  watermark.delta\n",
      "0           1     INSERT  ...  4.531706              5.8\n",
      "3           1     INSERT  ...  4.531706              5.8\n",
      "6           1     INSERT  ...  4.531706              5.8\n",
      "9           1     INSERT  ...  4.531706              5.8\n",
      "12          1     INSERT  ...  4.531706              5.8\n",
      "15          1     INSERT  ...  4.531706              5.8\n",
      "18          1     INSERT  ...  4.531706              5.8\n",
      "1           1     REMOVE  ...  4.531706              5.8\n",
      "4           1     REMOVE  ...  4.531706              5.8\n",
      "7           1     REMOVE  ...  4.531706              5.8\n",
      "10          1     REMOVE  ...  4.531706              5.8\n",
      "13          1     REMOVE  ...  4.531706              5.8\n",
      "16          1     REMOVE  ...  4.531706              5.8\n",
      "19          1     REMOVE  ...  4.531706              5.8\n",
      "2           1    REPLACE  ...  4.531706              5.8\n",
      "5           1    REPLACE  ...  4.531706              5.8\n",
      "8           1    REPLACE  ...  4.531706              5.8\n",
      "11          1    REPLACE  ...  4.531706              5.8\n",
      "14          1    REPLACE  ...  4.531706              5.8\n",
      "17          1    REPLACE  ...  4.531706              5.8\n",
      "20          1    REPLACE  ...  4.531706              5.8\n",
      "\n",
      "[21 rows x 14 columns]\n",
      "Namespace(model='meta-llama/Llama-2-7b-hf', delta=5.8, batch_idx=1, edits_count=7) 15_Llama-2-7b-hf_randAA_delta=5.8_w=2_1.pkl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "batch_idx=1 DONE: 100%|██████████| 21/21 [01:52<00:00,  5.38s/it]      5<01:52,  5.65s/it]        | 2/21 [00:10<01:43,  5.47s/it],  5.47s/it]▍        | 3/21 [00:16<01:37,  5.41s/it]1:37,  5.41s/it]�▉        | 4/21 [00:21<01:32,  5.42s/it]�█▍       | 5/21 [00:27<01:25,  5.37s/it]0:27<01:25,  5.37s/it]|██▊       | 6/21 [00:32<01:20,  5.35s/it]███▎      | 7/21 [00:37<01:15,  5.38s/it]21 [00:37<01:15,  5.38s/it]%|███▊      | 8/21 [00:43<01:09,  5.33s/it] 8/21 [00:43<01:09,  5.33s/it]3%|████▎     | 9/21 [00:48<01:03,  5.33s/it]48%|████▊     | 10/21 [00:53<00:59,  5.38s/it]     | 10/21 [00:53<00:59,  5.38s/it] 52%|█████▏    | 11/21 [00:58<00:52,  5.30s/it]�█▏    | 11/21 [00:58<00:52,  5.30s/it]E:  57%|█████▋    | 12/21 [01:04<00:47,  5.31s/it]:  62%|██████▏   | 13/21 [01:09<00:43,  5.39s/it]�███▏   | 13/21 [01:09<00:43,  5.39s/it]NE:  67%|██████▋   | 14/21 [01:15<00:37,  5.35s/it]�████▋   | 14/21 [01:15<00:37,  5.35s/it]ONE:  71%|███████▏  | 15/21 [01:20<00:32,  5.39s/it]██████▏  | 15/21 [01:20<00:32,  5.39s/it]DONE:  76%|███████▌  | 16/21 [01:26<00:27,  5.47s/it]�██████▌  | 16/21 [01:26<00:27,  5.47s/it]DONE:  81%|████████  | 17/21 [01:31<00:21,  5.34s/it]��███████  | 17/21 [01:31<00:21,  5.34s/it] DONE:  86%|████████▌ | 18/21 [01:36<00:16,  5.39s/it]|████████▌ | 18/21 [01:36<00:16,  5.39s/it]1 DONE:  90%|█████████ | 19/21 [01:42<00:11,  5.51s/it]%|█████████ | 19/21 [01:42<00:11,  5.51s/it]1 DONE:  95%|█████████▌| 20/21 [01:47<00:05,  5.35s/it] 95%|█████████▌| 20/21 [01:47<00:05,  5.35s/it]dx=1 DONE: 100%|██████████| 21/21 [01:52<00:00,  5.34s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "    batch_idx edits.type  ...  base.ppl  watermark.delta\n",
      "0           1     INSERT  ...  4.191895              5.8\n",
      "3           1     INSERT  ...  4.191895              5.8\n",
      "6           1     INSERT  ...  4.191895              5.8\n",
      "9           1     INSERT  ...  4.191895              5.8\n",
      "12          1     INSERT  ...  4.191895              5.8\n",
      "15          1     INSERT  ...  4.191895              5.8\n",
      "18          1     INSERT  ...  4.191895              5.8\n",
      "1           1     REMOVE  ...  4.191895              5.8\n",
      "4           1     REMOVE  ...  4.191895              5.8\n",
      "7           1     REMOVE  ...  4.191895              5.8\n",
      "10          1     REMOVE  ...  4.191895              5.8\n",
      "13          1     REMOVE  ...  4.191895              5.8\n",
      "16          1     REMOVE  ...  4.191895              5.8\n",
      "19          1     REMOVE  ...  4.191895              5.8\n",
      "2           1    REPLACE  ...  4.191895              5.8\n",
      "5           1    REPLACE  ...  4.191895              5.8\n",
      "8           1    REPLACE  ...  4.191895              5.8\n",
      "11          1    REPLACE  ...  4.191895              5.8\n",
      "14          1    REPLACE  ...  4.191895              5.8\n",
      "17          1    REPLACE  ...  4.191895              5.8\n",
      "20          1    REPLACE  ...  4.191895              5.8\n",
      "\n",
      "[21 rows x 14 columns]\n",
      "Namespace(model='meta-llama/Llama-2-7b-hf', delta=5.8, batch_idx=1, edits_count=7) 15_Llama-2-7b-hf_fixedAA (fixed)_delta=5.8_w=2_1.pkl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "batch_idx=1 DONE: 100%|██████████| 21/21 [01:39<00:00,  4.72s/it]      5<01:40,  5.02s/it]]        | 2/21 [00:09<01:32,  4.85s/it],  4.85s/it]▍        | 3/21 [00:14<01:25,  4.77s/it]1:25,  4.77s/it]�▉        | 4/21 [00:19<01:21,  4.78s/it]01:21,  4.78s/it]�█▍       | 5/21 [00:23<01:15,  4.73s/it]0:23<01:15,  4.73s/it]|██▊       | 6/21 [00:28<01:10,  4.70s/it][00:28<01:10,  4.70s/it]███▎      | 7/21 [00:33<01:06,  4.72s/it]21 [00:33<01:06,  4.72s/it]%|███▊      | 8/21 [00:37<01:00,  4.68s/it] 8/21 [00:37<01:00,  4.68s/it]3%|████▎     | 9/21 [00:42<00:56,  4.68s/it]   | 9/21 [00:42<00:56,  4.68s/it]48%|████▊     | 10/21 [00:47<00:52,  4.74s/it]     | 10/21 [00:47<00:52,  4.74s/it] 52%|█████▏    | 11/21 [00:51<00:46,  4.67s/it]�█▏    | 11/21 [00:51<00:46,  4.67s/it]E:  57%|█████▋    | 12/21 [00:56<00:41,  4.66s/it]██▋    | 12/21 [00:56<00:41,  4.66s/it]:  62%|██████▏   | 13/21 [01:01<00:37,  4.74s/it]�███▏   | 13/21 [01:01<00:37,  4.74s/it]NE:  67%|██████▋   | 14/21 [01:05<00:32,  4.67s/it]�████▋   | 14/21 [01:05<00:32,  4.67s/it]ONE:  71%|███████▏  | 15/21 [01:10<00:28,  4.73s/it]██████▏  | 15/21 [01:10<00:28,  4.73s/it]DONE:  76%|███████▌  | 16/21 [01:15<00:24,  4.81s/it]�██████▌  | 16/21 [01:15<00:24,  4.81s/it]DONE:  81%|████████  | 17/21 [01:20<00:18,  4.69s/it] DONE:  86%|████████▌ | 18/21 [01:24<00:14,  4.69s/it]|████████▌ | 18/21 [01:24<00:14,  4.69s/it]1 DONE:  90%|█████████ | 19/21 [01:29<00:09,  4.79s/it]%|█████████ | 19/21 [01:29<00:09,  4.79s/it]1 DONE:  95%|█████████▌| 20/21 [01:34<00:04,  4.68s/it] 95%|█████████▌| 20/21 [01:34<00:04,  4.68s/it]dx=1 DONE: 100%|██████████| 21/21 [01:39<00:00,  4.70s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "    batch_idx edits.type  ...  base.ppl  watermark.delta\n",
      "0           1     INSERT  ...  4.027327              5.8\n",
      "3           1     INSERT  ...  4.027327              5.8\n",
      "6           1     INSERT  ...  4.027327              5.8\n",
      "9           1     INSERT  ...  4.027327              5.8\n",
      "12          1     INSERT  ...  4.027327              5.8\n",
      "15          1     INSERT  ...  4.027327              5.8\n",
      "18          1     INSERT  ...  4.027327              5.8\n",
      "1           1     REMOVE  ...  4.027327              5.8\n",
      "4           1     REMOVE  ...  4.027327              5.8\n",
      "7           1     REMOVE  ...  4.027327              5.8\n",
      "10          1     REMOVE  ...  4.027327              5.8\n",
      "13          1     REMOVE  ...  4.027327              5.8\n",
      "16          1     REMOVE  ...  4.027327              5.8\n",
      "19          1     REMOVE  ...  4.027327              5.8\n",
      "2           1    REPLACE  ...  4.027327              5.8\n",
      "5           1    REPLACE  ...  4.027327              5.8\n",
      "8           1    REPLACE  ...  4.027327              5.8\n",
      "11          1    REPLACE  ...  4.027327              5.8\n",
      "14          1    REPLACE  ...  4.027327              5.8\n",
      "17          1    REPLACE  ...  4.027327              5.8\n",
      "20          1    REPLACE  ...  4.027327              5.8\n",
      "\n",
      "[21 rows x 14 columns]\n",
      "Namespace(model='meta-llama/Llama-2-7b-hf', delta=5.8, batch_idx=1, edits_count=7) 15_Llama-2-7b-hf_randACBC_delta=5.8_w=4_1.pkl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "batch_idx=1 DONE: 100%|█████████▌| 20/21 [02:25<00:06,  6.87s/it]      7<02:22,  7.12s/it]        | 2/21 [00:13<02:11,  6.91s/it],  6.91s/it]▍        | 3/21 [00:20<02:03,  6.88s/it]2:03,  6.88s/it]�▉        | 4/21 [00:27<01:59,  7.02s/it]01:59,  7.02s/it]�█▍       | 5/21 [00:34<01:51,  6.95s/it]0:34<01:51,  6.95s/it]|██▊       | 6/21 [00:41<01:44,  6.97s/it][00:41<01:44,  6.97s/it]███▎      | 7/21 [00:48<01:37,  7.00s/it]21 [00:48<01:37,  7.00s/it]%|███▊      | 8/21 [00:55<01:29,  6.90s/it] 8/21 [00:55<01:29,  6.90s/it]3%|████▎     | 9/21 [01:02<01:22,  6.91s/it]   | 9/21 [01:02<01:22,  6.91s/it]48%|████▊     | 10/21 [01:09<01:16,  6.98s/it]     | 10/21 [01:09<01:16,  6.98s/it] 52%|█████▏    | 11/21 [01:16<01:08,  6.86s/it]�█▏    | 11/21 [01:16<01:08,  6.86s/it]E:  57%|█████▋    | 12/21 [01:23<01:01,  6.88s/it]██▋    | 12/21 [01:23<01:01,  6.88s/it]:  62%|██████▏   | 13/21 [01:30<00:55,  6.99s/it]�███▏   | 13/21 [01:30<00:55,  6.99s/it]NE:  67%|██████▋   | 14/21 [01:36<00:48,  6.86s/it]�████▋   | 14/21 [01:36<00:48,  6.86s/it]ONE:  71%|███████▏  | 15/21 [01:44<00:41,  6.97s/it]██████▏  | 15/21 [01:44<00:41,  6.97s/it]DONE:  76%|███████▌  | 16/21 [01:51<00:35,  7.14s/it]�██████▌  | 16/21 [01:51<00:35,  7.14s/it]DONE:  81%|████████  | 17/21 [01:58<00:27,  6.99s/it]��███████  | 17/21 [01:58<00:27,  6.99s/it] DONE:  86%|████████▌ | 18/21 [02:05<00:20,  6.97s/it]|████████▌ | 18/21 [02:05<00:20,  6.97s/it]1 DONE:  90%|█████████ | 19/21 [02:12<00:14,  7.11s/it]%|█████████ | 19/21 [02:12<00:14,  7.11s/it]1 DONE:  95%|█████████▌| 20/21 [02:19<00:06,  6.87s/it] 95%|█████████▌| 20/21 [02:19<00:06,  6.87s/it]dx=1 DONE: 100%|██████████| 21/21 [02:25<00:00,  6.89s/it]%|██████████| 21/21 [02:25<00:00,  6.95s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "    batch_idx edits.type  ...  base.ppl  watermark.delta\n",
      "0           1     INSERT  ...  6.917051              5.8\n",
      "3           1     INSERT  ...  6.917051              5.8\n",
      "6           1     INSERT  ...  6.917051              5.8\n",
      "9           1     INSERT  ...  6.917051              5.8\n",
      "12          1     INSERT  ...  6.917051              5.8\n",
      "15          1     INSERT  ...  6.917051              5.8\n",
      "18          1     INSERT  ...  6.917051              5.8\n",
      "1           1     REMOVE  ...  6.917051              5.8\n",
      "4           1     REMOVE  ...  6.917051              5.8\n",
      "7           1     REMOVE  ...  6.917051              5.8\n",
      "10          1     REMOVE  ...  6.917051              5.8\n",
      "13          1     REMOVE  ...  6.917051              5.8\n",
      "16          1     REMOVE  ...  6.917051              5.8\n",
      "19          1     REMOVE  ...  6.917051              5.8\n",
      "2           1    REPLACE  ...  6.917051              5.8\n",
      "5           1    REPLACE  ...  6.917051              5.8\n",
      "8           1    REPLACE  ...  6.917051              5.8\n",
      "11          1    REPLACE  ...  6.917051              5.8\n",
      "14          1    REPLACE  ...  6.917051              5.8\n",
      "17          1    REPLACE  ...  6.917051              5.8\n",
      "20          1    REPLACE  ...  6.917051              5.8\n",
      "\n",
      "[21 rows x 14 columns]\n",
      "Namespace(model='meta-llama/Llama-2-7b-hf', delta=6.8, batch_idx=1, edits_count=7) 15_Llama-2-7b-hf_randACADBCBD_delta=6.8_w=8_1.pkl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loading checkpoint shards: 100%|██████████| 2/2 [00:14<00:00,  6.73s/it]g checkpoint shards: 100%|██████████| 2/2 [00:14<00:00,  7.36s/it]\n",
      "batch_idx=1 DONE: 100%|█████████▌| 20/21 [03:32<00:10, 10.18s/it]      9<03:15,  9.78s/it]]        | 2/21 [00:19<03:02,  9.63s/it],  9.63s/it]▍        | 3/21 [00:28<02:51,  9.53s/it]�▉        | 4/21 [00:38<02:46,  9.80s/it]�█▍       | 5/21 [00:48<02:36,  9.81s/it]0:48<02:36,  9.81s/it]|██▊       | 6/21 [00:58<02:27,  9.84s/it][00:58<02:27,  9.84s/it]███▎      | 7/21 [01:08<02:19,  9.97s/it]21 [01:08<02:19,  9.97s/it]%|███▊      | 8/21 [01:18<02:08,  9.90s/it] 8/21 [01:18<02:08,  9.90s/it]3%|████▎     | 9/21 [01:28<02:00, 10.01s/it]   | 9/21 [01:28<02:00, 10.01s/it]48%|████▊     | 10/21 [01:39<01:51, 10.12s/it]     | 10/21 [01:39<01:51, 10.12s/it] 52%|█████▏    | 11/21 [01:48<01:39,  9.95s/it]�█▏    | 11/21 [01:48<01:39,  9.95s/it]E:  57%|█████▋    | 12/21 [01:59<01:31, 10.13s/it]██▋    | 12/21 [01:59<01:31, 10.13s/it]:  62%|██████▏   | 13/21 [02:10<01:24, 10.56s/it]NE:  67%|██████▋   | 14/21 [02:20<01:12, 10.31s/it]�████▋   | 14/21 [02:20<01:12, 10.31s/it]ONE:  71%|███████▏  | 15/21 [02:30<01:01, 10.32s/it]DONE:  76%|███████▌  | 16/21 [02:41<00:52, 10.48s/it]�██████▌  | 16/21 [02:41<00:52, 10.48s/it]DONE:  81%|████████  | 17/21 [02:51<00:40, 10.21s/it]��███████  | 17/21 [02:51<00:40, 10.21s/it] DONE:  86%|████████▌ | 18/21 [03:01<00:30, 10.28s/it]|████████▌ | 18/21 [03:01<00:30, 10.28s/it]1 DONE:  90%|█████████ | 19/21 [03:12<00:20, 10.44s/it]%|█████████ | 19/21 [03:12<00:20, 10.44s/it]1 DONE:  95%|█████████▌| 20/21 [03:22<00:10, 10.18s/it] 95%|█████████▌| 20/21 [03:22<00:10, 10.18s/it]dx=1 DONE: 100%|██████████| 21/21 [03:32<00:00, 10.25s/it]%|██████████| 21/21 [03:32<00:00, 10.13s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "    batch_idx edits.type  ...   base.ppl  watermark.delta\n",
      "0           1     INSERT  ...  10.080597              6.8\n",
      "3           1     INSERT  ...  10.080597              6.8\n",
      "6           1     INSERT  ...  10.080597              6.8\n",
      "9           1     INSERT  ...  10.080597              6.8\n",
      "12          1     INSERT  ...  10.080597              6.8\n",
      "15          1     INSERT  ...  10.080597              6.8\n",
      "18          1     INSERT  ...  10.080597              6.8\n",
      "1           1     REMOVE  ...  10.080597              6.8\n",
      "4           1     REMOVE  ...  10.080597              6.8\n",
      "7           1     REMOVE  ...  10.080597              6.8\n",
      "10          1     REMOVE  ...  10.080597              6.8\n",
      "13          1     REMOVE  ...  10.080597              6.8\n",
      "16          1     REMOVE  ...  10.080597              6.8\n",
      "19          1     REMOVE  ...  10.080597              6.8\n",
      "2           1    REPLACE  ...  10.080597              6.8\n",
      "5           1    REPLACE  ...  10.080597              6.8\n",
      "8           1    REPLACE  ...  10.080597              6.8\n",
      "11          1    REPLACE  ...  10.080597              6.8\n",
      "14          1    REPLACE  ...  10.080597              6.8\n",
      "17          1    REPLACE  ...  10.080597              6.8\n",
      "20          1    REPLACE  ...  10.080597              6.8\n",
      "\n",
      "[21 rows x 14 columns]\n",
      "Namespace(model='meta-llama/Llama-2-7b-hf', delta=6.8, batch_idx=1, edits_count=7) 15_Llama-2-7b-hf_randAB_delta=6.8_w=2_1.pkl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "batch_idx=1 DONE: 100%|██████████| 21/21 [01:52<00:00,  5.36s/it]      5<01:54,  5.71s/it]]        | 2/21 [00:10<01:43,  5.44s/it],  5.44s/it]▍        | 3/21 [00:16<01:36,  5.38s/it]1:36,  5.38s/it]�▉        | 4/21 [00:21<01:32,  5.44s/it]�█▍       | 5/21 [00:27<01:26,  5.38s/it]|██▊       | 6/21 [00:32<01:20,  5.37s/it][00:32<01:20,  5.37s/it]███▎      | 7/21 [00:37<01:15,  5.40s/it]21 [00:37<01:15,  5.40s/it]%|███▊      | 8/21 [00:43<01:09,  5.31s/it]3%|████▎     | 9/21 [00:48<01:03,  5.31s/it] 52%|█████▏    | 11/21 [00:59<00:53,  5.32s/it]E:  57%|█████▋    | 12/21 [01:04<00:48,  5.38s/it]██▋    | 12/21 [01:04<00:48,  5.38s/it]:  62%|██████▏   | 13/21 [01:10<00:43,  5.45s/it]�███▏   | 13/21 [01:10<00:43,  5.45s/it]NE:  67%|██████▋   | 14/21 [01:15<00:37,  5.33s/it]�████▋   | 14/21 [01:15<00:37,  5.33s/it]ONE:  71%|███████▏  | 15/21 [01:20<00:31,  5.33s/it]██████▏  | 15/21 [01:20<00:31,  5.33s/it]DONE:  76%|███████▌  | 16/21 [01:26<00:27,  5.41s/it]�██████▌  | 16/21 [01:26<00:27,  5.41s/it]DONE:  81%|████████  | 17/21 [01:31<00:21,  5.29s/it]��███████  | 17/21 [01:31<00:21,  5.29s/it] DONE:  86%|████████▌ | 18/21 [01:36<00:15,  5.30s/it]|████████▌ | 18/21 [01:36<00:15,  5.30s/it]1 DONE:  90%|█████████ | 19/21 [01:42<00:10,  5.39s/it]%|█████████ | 19/21 [01:42<00:10,  5.39s/it]1 DONE:  95%|█████████▌| 20/21 [01:47<00:05,  5.27s/it] 95%|█████████▌| 20/21 [01:47<00:05,  5.27s/it]dx=1 DONE: 100%|██████████| 21/21 [01:52<00:00,  5.32s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "    batch_idx edits.type  ...  base.ppl  watermark.delta\n",
      "0           1     INSERT  ...  4.748683              6.8\n",
      "3           1     INSERT  ...  4.748683              6.8\n",
      "6           1     INSERT  ...  4.748683              6.8\n",
      "9           1     INSERT  ...  4.748683              6.8\n",
      "12          1     INSERT  ...  4.748683              6.8\n",
      "15          1     INSERT  ...  4.748683              6.8\n",
      "18          1     INSERT  ...  4.748683              6.8\n",
      "1           1     REMOVE  ...  4.748683              6.8\n",
      "4           1     REMOVE  ...  4.748683              6.8\n",
      "7           1     REMOVE  ...  4.748683              6.8\n",
      "10          1     REMOVE  ...  4.748683              6.8\n",
      "13          1     REMOVE  ...  4.748683              6.8\n",
      "16          1     REMOVE  ...  4.748683              6.8\n",
      "19          1     REMOVE  ...  4.748683              6.8\n",
      "2           1    REPLACE  ...  4.748683              6.8\n",
      "5           1    REPLACE  ...  4.748683              6.8\n",
      "8           1    REPLACE  ...  4.748683              6.8\n",
      "11          1    REPLACE  ...  4.748683              6.8\n",
      "14          1    REPLACE  ...  4.748683              6.8\n",
      "17          1    REPLACE  ...  4.748683              6.8\n",
      "20          1    REPLACE  ...  4.748683              6.8\n",
      "\n",
      "[21 rows x 14 columns]\n",
      "Namespace(model='meta-llama/Llama-2-7b-hf', delta=6.8, batch_idx=1, edits_count=7) 15_Llama-2-7b-hf_randAA_delta=6.8_w=2_1.pkl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "batch_idx=1 DONE: 100%|█████████▌| 20/21 [01:52<00:05,  5.28s/it]      5<01:55,  5.76s/it]]        | 2/21 [00:11<01:44,  5.50s/it],  5.50s/it]▍        | 3/21 [00:16<01:37,  5.41s/it]1:37,  5.41s/it]�▉        | 4/21 [00:21<01:31,  5.41s/it]01:31,  5.41s/it]�█▍       | 5/21 [00:27<01:25,  5.34s/it]0:27<01:25,  5.34s/it]|██▊       | 6/21 [00:32<01:19,  5.32s/it][00:32<01:19,  5.32s/it]███▎      | 7/21 [00:37<01:15,  5.37s/it]21 [00:37<01:15,  5.37s/it]%|███▊      | 8/21 [00:42<01:09,  5.31s/it] 8/21 [00:42<01:09,  5.31s/it]3%|████▎     | 9/21 [00:48<01:03,  5.32s/it]   | 9/21 [00:48<01:03,  5.32s/it]48%|████▊     | 10/21 [00:53<00:59,  5.39s/it]     | 10/21 [00:53<00:59,  5.39s/it] 52%|█████▏    | 11/21 [00:58<00:53,  5.30s/it]�█▏    | 11/21 [00:58<00:53,  5.30s/it]E:  57%|█████▋    | 12/21 [01:04<00:47,  5.32s/it]██▋    | 12/21 [01:04<00:47,  5.32s/it]:  62%|██████▏   | 13/21 [01:09<00:43,  5.43s/it]�███▏   | 13/21 [01:09<00:43,  5.43s/it]NE:  67%|██████▋   | 14/21 [01:15<00:37,  5.33s/it]�████▋   | 14/21 [01:15<00:37,  5.33s/it]ONE:  71%|███████▏  | 15/21 [01:20<00:31,  5.33s/it]██████▏  | 15/21 [01:20<00:31,  5.33s/it]DONE:  76%|███████▌  | 16/21 [01:25<00:26,  5.40s/it]�██████▌  | 16/21 [01:25<00:26,  5.40s/it]DONE:  81%|████████  | 17/21 [01:30<00:21,  5.28s/it]��███████  | 17/21 [01:30<00:21,  5.28s/it] DONE:  86%|████████▌ | 18/21 [01:36<00:15,  5.31s/it]|████████▌ | 18/21 [01:36<00:15,  5.31s/it]1 DONE:  90%|█████████ | 19/21 [01:42<00:10,  5.41s/it]%|█████████ | 19/21 [01:42<00:10,  5.41s/it]1 DONE:  95%|█████████▌| 20/21 [01:46<00:05,  5.28s/it] 95%|█████████▌| 20/21 [01:46<00:05,  5.28s/it]dx=1 DONE: 100%|██████████| 21/21 [01:52<00:00,  5.31s/it]%|██████████| 21/21 [01:52<00:00,  5.35s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "    batch_idx edits.type  ...  base.ppl  watermark.delta\n",
      "0           1     INSERT  ...  4.291515              6.8\n",
      "3           1     INSERT  ...  4.291515              6.8\n",
      "6           1     INSERT  ...  4.291515              6.8\n",
      "9           1     INSERT  ...  4.291515              6.8\n",
      "12          1     INSERT  ...  4.291515              6.8\n",
      "15          1     INSERT  ...  4.291515              6.8\n",
      "18          1     INSERT  ...  4.291515              6.8\n",
      "1           1     REMOVE  ...  4.291515              6.8\n",
      "4           1     REMOVE  ...  4.291515              6.8\n",
      "7           1     REMOVE  ...  4.291515              6.8\n",
      "10          1     REMOVE  ...  4.291515              6.8\n",
      "13          1     REMOVE  ...  4.291515              6.8\n",
      "16          1     REMOVE  ...  4.291515              6.8\n",
      "19          1     REMOVE  ...  4.291515              6.8\n",
      "2           1    REPLACE  ...  4.291515              6.8\n",
      "5           1    REPLACE  ...  4.291515              6.8\n",
      "8           1    REPLACE  ...  4.291515              6.8\n",
      "11          1    REPLACE  ...  4.291515              6.8\n",
      "14          1    REPLACE  ...  4.291515              6.8\n",
      "17          1    REPLACE  ...  4.291515              6.8\n",
      "20          1    REPLACE  ...  4.291515              6.8\n",
      "\n",
      "[21 rows x 14 columns]\n",
      "Namespace(model='meta-llama/Llama-2-7b-hf', delta=6.8, batch_idx=1, edits_count=7) 15_Llama-2-7b-hf_fixedAA (fixed)_delta=6.8_w=2_1.pkl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "batch_idx=1 DONE: 100%|█████████▌| 20/21 [02:15<00:06,  6.54s/it]      6<02:18,  6.92s/it]]        | 2/21 [00:13<02:09,  6.82s/it],  6.82s/it]▍        | 3/21 [00:20<02:00,  6.72s/it]2:00,  6.72s/it]�▉        | 4/21 [00:25<01:46,  6.26s/it]01:46,  6.26s/it]�█▍       | 5/21 [00:30<01:31,  5.70s/it]|██▊       | 6/21 [00:36<01:26,  5.78s/it][00:36<01:26,  5.78s/it]███▎      | 7/21 [00:43<01:25,  6.11s/it]21 [00:43<01:25,  6.11s/it]%|███▊      | 8/21 [00:49<01:21,  6.23s/it] 8/21 [00:49<01:21,  6.23s/it]3%|████▎     | 9/21 [00:56<01:16,  6.39s/it]   | 9/21 [00:56<01:16,  6.39s/it]48%|████▊     | 10/21 [01:03<01:12,  6.55s/it]     | 10/21 [01:03<01:12,  6.55s/it] 52%|█████▏    | 11/21 [01:09<01:04,  6.47s/it]�█▏    | 11/21 [01:09<01:04,  6.47s/it]E:  57%|█████▋    | 12/21 [01:16<00:58,  6.48s/it]██▋    | 12/21 [01:16<00:58,  6.48s/it]:  62%|██████▏   | 13/21 [01:23<00:52,  6.61s/it]�███▏   | 13/21 [01:23<00:52,  6.61s/it]NE:  67%|██████▋   | 14/21 [01:29<00:45,  6.50s/it]�████▋   | 14/21 [01:29<00:45,  6.50s/it]ONE:  71%|███████▏  | 15/21 [01:35<00:39,  6.53s/it]██████▏  | 15/21 [01:35<00:39,  6.53s/it]DONE:  76%|███████▌  | 16/21 [01:42<00:33,  6.65s/it]�██████▌  | 16/21 [01:42<00:33,  6.65s/it]DONE:  81%|████████  | 17/21 [01:49<00:26,  6.53s/it]��███████  | 17/21 [01:49<00:26,  6.53s/it] DONE:  86%|████████▌ | 18/21 [01:55<00:19,  6.57s/it]|████████▌ | 18/21 [01:55<00:19,  6.57s/it]1 DONE:  90%|█████████ | 19/21 [02:02<00:13,  6.71s/it]1 DONE:  95%|█████████▌| 20/21 [02:08<00:06,  6.54s/it] 95%|█████████▌| 20/21 [02:08<00:06,  6.54s/it]dx=1 DONE: 100%|██████████| 21/21 [02:15<00:00,  6.56s/it]%|██████████| 21/21 [02:15<00:00,  6.46s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "    batch_idx edits.type  ...  base.ppl  watermark.delta\n",
      "0           1     INSERT  ...  4.311801              6.8\n",
      "3           1     INSERT  ...  4.311801              6.8\n",
      "6           1     INSERT  ...  4.311801              6.8\n",
      "9           1     INSERT  ...  4.311801              6.8\n",
      "12          1     INSERT  ...  4.311801              6.8\n",
      "15          1     INSERT  ...  4.311801              6.8\n",
      "18          1     INSERT  ...  4.311801              6.8\n",
      "1           1     REMOVE  ...  4.311801              6.8\n",
      "4           1     REMOVE  ...  4.311801              6.8\n",
      "7           1     REMOVE  ...  4.311801              6.8\n",
      "10          1     REMOVE  ...  4.311801              6.8\n",
      "13          1     REMOVE  ...  4.311801              6.8\n",
      "16          1     REMOVE  ...  4.311801              6.8\n",
      "19          1     REMOVE  ...  4.311801              6.8\n",
      "2           1    REPLACE  ...  4.311801              6.8\n",
      "5           1    REPLACE  ...  4.311801              6.8\n",
      "8           1    REPLACE  ...  4.311801              6.8\n",
      "11          1    REPLACE  ...  4.311801              6.8\n",
      "14          1    REPLACE  ...  4.311801              6.8\n",
      "17          1    REPLACE  ...  4.311801              6.8\n",
      "20          1    REPLACE  ...  4.311801              6.8\n",
      "\n",
      "[21 rows x 14 columns]\n",
      "Namespace(model='meta-llama/Llama-2-7b-hf', delta=6.8, batch_idx=1, edits_count=7) 15_Llama-2-7b-hf_randACBC_delta=6.8_w=4_1.pkl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "batch_idx=1 DONE: 100%|█████████▌| 20/21 [02:22<00:06,  6.79s/it]      7<02:20,  7.00s/it]]        | 2/21 [00:13<02:10,  6.87s/it],  6.87s/it]▍        | 3/21 [00:20<02:01,  6.77s/it]2:01,  6.77s/it]�▉        | 4/21 [00:27<01:55,  6.82s/it]01:55,  6.82s/it]�█▍       | 5/21 [00:34<01:48,  6.80s/it]0:34<01:48,  6.80s/it]|██▊       | 6/21 [00:40<01:41,  6.79s/it][00:40<01:41,  6.79s/it]███▎      | 7/21 [00:47<01:35,  6.84s/it]21 [00:47<01:35,  6.84s/it]%|███▊      | 8/21 [00:54<01:27,  6.74s/it] 8/21 [00:54<01:27,  6.74s/it]3%|████▎     | 9/21 [01:01<01:21,  6.76s/it]   | 9/21 [01:01<01:21,  6.76s/it]48%|████▊     | 10/21 [01:08<01:15,  6.87s/it]     | 10/21 [01:08<01:15,  6.87s/it] 52%|█████▏    | 11/21 [01:14<01:07,  6.75s/it]�█▏    | 11/21 [01:14<01:07,  6.75s/it]E:  57%|█████▋    | 12/21 [01:21<01:00,  6.75s/it]██▋    | 12/21 [01:21<01:00,  6.75s/it]:  62%|██████▏   | 13/21 [01:28<00:54,  6.84s/it]�███▏   | 13/21 [01:28<00:54,  6.84s/it]NE:  67%|██████▋   | 14/21 [01:34<00:47,  6.72s/it]ONE:  71%|███████▏  | 15/21 [01:41<00:40,  6.75s/it]██████▏  | 15/21 [01:41<00:40,  6.75s/it]DONE:  76%|███████▌  | 16/21 [01:48<00:34,  6.87s/it]�██████▌  | 16/21 [01:48<00:34,  6.87s/it]DONE:  81%|████████  | 17/21 [01:55<00:26,  6.70s/it]��███████  | 17/21 [01:55<00:26,  6.70s/it] DONE:  86%|████████▌ | 18/21 [02:02<00:20,  6.77s/it]|████████▌ | 18/21 [02:02<00:20,  6.77s/it]1 DONE:  90%|█████████ | 19/21 [02:09<00:13,  6.92s/it]%|█████████ | 19/21 [02:09<00:13,  6.92s/it]1 DONE:  95%|█████████▌| 20/21 [02:15<00:06,  6.79s/it] 95%|█████████▌| 20/21 [02:15<00:06,  6.79s/it]dx=1 DONE: 100%|██████████| 21/21 [02:22<00:00,  6.86s/it]%|██████████| 21/21 [02:22<00:00,  6.81s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "    batch_idx edits.type  ...  base.ppl  watermark.delta\n",
      "0           1     INSERT  ...  7.533406              6.8\n",
      "3           1     INSERT  ...  7.533406              6.8\n",
      "6           1     INSERT  ...  7.533406              6.8\n",
      "9           1     INSERT  ...  7.533406              6.8\n",
      "12          1     INSERT  ...  7.533406              6.8\n",
      "15          1     INSERT  ...  7.533406              6.8\n",
      "18          1     INSERT  ...  7.533406              6.8\n",
      "1           1     REMOVE  ...  7.533406              6.8\n",
      "4           1     REMOVE  ...  7.533406              6.8\n",
      "7           1     REMOVE  ...  7.533406              6.8\n",
      "10          1     REMOVE  ...  7.533406              6.8\n",
      "13          1     REMOVE  ...  7.533406              6.8\n",
      "16          1     REMOVE  ...  7.533406              6.8\n",
      "19          1     REMOVE  ...  7.533406              6.8\n",
      "2           1    REPLACE  ...  7.533406              6.8\n",
      "5           1    REPLACE  ...  7.533406              6.8\n",
      "8           1    REPLACE  ...  7.533406              6.8\n",
      "11          1    REPLACE  ...  7.533406              6.8\n",
      "14          1    REPLACE  ...  7.533406              6.8\n",
      "17          1    REPLACE  ...  7.533406              6.8\n",
      "20          1    REPLACE  ...  7.533406              6.8\n",
      "\n",
      "[21 rows x 14 columns]\n"
     ]
    }
   ],
   "source": [
    "%%bash\n",
    "for idx in 1; do for model in \"meta-llama/Llama-2-7b-hf\"; do for delta in 4.8 5.8 6.8;\\\n",
    "    do python 15_exp_edit_detection_vs_width.py --model=\"$model\" --delta=$delta --edits_count=7 --batch_idx=$idx; done; done; done"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "5c843e97",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "dict_keys(['AA (Unigram baseline)', 'AA (KGW baseline)', 'AB (Combinatorial Pattern)', 'ACADBCBD (Combinatorial Pattern)'])\n"
     ]
    }
   ],
   "source": [
    "import glob\n",
    "from utils import *\n",
    "\n",
    "name_to_data = {}\n",
    "for path in sorted(glob.glob(f'*Llama*_1.pkl', recursive=True)):\n",
    "    with open(path, 'rb') as file: df = pickle.load(file)\n",
    "    pattern, delta = path.split(\"hf_\")[1].split(\"_w=\")[0].split(\"_\")\n",
    "    pattern = pattern.replace(\"fixedAA (fixed)\", \"AA (Unigram baseline)\")\n",
    "    pattern = pattern.replace(\"randAA\", \"AA (KGW baseline)\")\n",
    "    pattern = pattern.replace(\"randAB\", \"AB (Combinatorial Pattern)\")\n",
    "    pattern = pattern.replace(\"randACBC\", \"ACBC (Combinatorial Pattern)\")\n",
    "    pattern = pattern.replace(\"randACADBCBD\", \"ACADBCBD (Combinatorial Pattern)\")\n",
    "    if \"ACBC \" in pattern or \".8\" not in path: continue\n",
    "    delta = float(delta.split('=')[1])\n",
    "    if pattern not in name_to_data: name_to_data[pattern] = []\n",
    "    if delta < 4 or delta > 7: continue\n",
    "    df[\"diff.wm_detection.scores\"] = df[\"wm_detection.scores\"] - df[\"base.wm_detection.scores\"]\n",
    "    name_to_data[pattern].append((df, delta))\n",
    "print(name_to_data.keys())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "343f3f3c",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_11266/1873200923.py:48: UserWarning: Tight layout not applied. tight_layout cannot make Axes width small enough to accommodate all Axes decorations\n",
      "  plt.tight_layout()\n"
     ]
    },
    {
     "data": {
      "image/png": "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Ri+0wnEyRm8wRm+0Qoz1aoVjZIzeYIzeaIUYm4GvWLQYE4GIiIiIiIhaSss8rklERERERET2mOQRERERERG1ESZ5REREREREbYRJHhERERERURthkkdERERERNRGmOQRERERERG1ESZ5REREREREbYRJHhERERERURthkkdERERERNRGmOQRERERERG1ESZ5REREREREbYRJHhERERERURthkkdERERERNRGmOQRERERERG1ESZ5REREREREbYRJHhERERERURthkkdERERERNRGmOQRERERERG1EU+TvBMnTni5uSqKoqCvr892OVVVMTMzg3Q6jZmZGWiatqZxERERERERNQtfsVgsul352LFjKBQK+ud4PI7Z2VlPAquUTqchiiL6+vpgF3JfXx9yuRyAlYQvGo0ilUqtSVxERERERETNxHVL3ujoKCYmJrBv3z79T1EU2/UmJydd7W94eBjBYNB2OVVVyz6LoghZll3t062lpSX89re/xdLSUkP3WwvG6A3G6I1WiNELrXCcjNEbjNEbrRBjvVrhGBmjNxijN1ohxmawye2Kg4ODGB8fL5t24MAB2/VSqRQCgQBCoRBuu+02t7s3Jcsy/H5/2TS/3w9FUQyTxEuXLuHSpUtl0zZt2oSOjg7XMSwtLWF5ebmpLz7G6A3G6A2vYty4caNHEbFuYIz1YYze8CJG1gv1Y4zeYIzeaMZ7hmbkOskLBAKOplXK5XLo6urCwsICDh48CAC4++673YZRxez9u9WPla42NTWFJ554omzaQw89hIcffth1DMvLy4h+50Fc+fAiAJ/hMr995xS2/fmfG87r7u7GT3/6U9f7d2J5eRmFQgHHjx/Hhg3N2f+OkxgffvhhnDt3znAez+OKdjmPTmK89dZbPYtpreqGdrhe1ptdjOt9PQM8j17x4jy2Qr1gdc9gdb8ANEcdbXWtAI2LsdXPYzNoh/Po9Hr0sm5oRq6TvHw+j3g8jv7+fgBAsVhEMplENpu1XK+rqwsA0NPTA1mWEYvFMDs7i7GxMQSDQdx0001uQ7JklvxNTk7i0UcfLZvmxa9yVz68iFfvv8N0mc9O/gxf+cpXDOflcjncfPPNrvfvxNLSEo4fP44vfvGLTftLhpMYL1682JDz+Dd334O3TxtUGEXAv/XPMPdf/9U0xm9+85s4deqU4bwbbrgBL730kicx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J598EmfOnNE/d3R0OE7yanpcc7VkMomzZz8ZPmDHjh2QZdl2venpaRSLRZw9exZHjhxBPp9HoVBwtE9VVTEzM4N0Oo2ZmRlomma6rKIoUBRFX6/0/0RERERERG5s375dzytqTfAA4DOf+QzeeOMNvPHGG1heXrbcxupcq1auW/K6u7sxPj5e83rxeLzqMc+5uTlH646MjOjdx6qqivHxcaRSKdP9JBIJACvj95ktR0RERETUCD945Du48tFFDqPT4j71qU+ho6MDly5dcrW+0+TQ5/PB5/PhJz/5CQ4dOoQvf/nLjvfhOsk7cuQIBgcHsXXrVn1aNputet+uktF7fIFAwHZ/qqqWfRZF0bLlsK+vD4uLiwAAQRBst09ERER0NbvjrlG8c6q65aAIwL/lWvzbqz9vfFBt5iOtgFfvv91wXiOH0bH6rq85fbphcbSiLVu24JZbboGiKNi7d6/jxydLPvjgA308xN/97nf48Y9/bLqN119/HV/96lfxyCOPYPPmzTUlla6TvEgkgt7eXgQCAQiCAEVREI/Hbdebn58v+6xpGuLxOF577TXL9WRZht/vL5vm9/uhKAqCwaDhOkzuiIiIiJx559RZfPC1xwznXclMNTia1tUKCZTVd731xUiDo2kdGzduRCQSwbPPPouOjg4888wzCIVCuOOOOyzXu/baa/V361566SW9Je/BBx/EI488Yprkffe738U3vvEN/OY3v8GJEydqaj10neT19PQgl8shmUxC0zRMT0+jp6fHdr1wOIy+vj4Ui0UAK8nb4OCg7Xpm79+Zvc+naRrS6TSAlRbGSCQCURSrlrt06VLVydq0aRM6OjpsYyraLuFeaSxBZ9YyEnPOY1yf+ADG6JVWiXHjxo2ebc9t3cB6gTF6gTF6o1nqBSsr57G+81Pbd2HOKopinfvxKkbr7TfHeXz71Fl8uEYJVCO+63o14rteXl6u+3qstW7Yu3cvisWi3hNmqbPJ7du344MPPnC8nf/yX/6LnuR961vfwnPPPWfYIrh371787ne/019V27t3Lx555BHHrYeukzwASCQSOHr0KGZnZzE3N4fu7m7b3jVjsRiGhobKpjl9J8+IWfIXDof1ljxRFDE4OIh8Pl+13NTUFJ544omyaQ899BAefvhh231fuXzZdJ5d4SkluUYuX76M3//+97b7/2T5KwCuqXk/jYrRKj67/TDG1csyRvP9rsR466232mzFObd1g1W9ANjcRDVBvQAwxvLlGaPxPlsnxmaoF6ys3Kwum863Oz+1fhdWrOqvP51awN997SuAwbtk773zvv74mREvYxz/x8dwqnC+anoRwKcWzVvJmuU8ur2egasvRjPLy8soFAo4fvw4Nmyo7kPyss2/w27rhhdeeAHXXXed/vnChQsYGRnB4cOHHbfkPfjgg3juueeqhkwIhUKG+7vlllv0z7t27cKTTz6JN99801G8rpO83bt3IxAIQJIkACvv2h08eND2nbzKBA9YeanQjiAIVa12hULB9JFMVVX1xzhFUYSqqlBVtao1b3JyEo8++mjZNKe/yl2zeTPMLiO7I7I65s2bN+Pmm2+23f8ny5vfVFvtp1ExWsVntx/GuHpZxmi+39rKjBNWdcPot/4WZxbfNVzv7NlLsPqpy+o4m6FeABhj+fKM0Xif7RejE/XcM5hZaVEw7+zc7vx4eZxW9zVbNvnw6v3GN7J275J5GWPhg49xeXDScN6SRStZs5xHt9czcPXFaGZpaQljO/8Gf/rwA8Ngz509Uz1xFbcx3nDDDfj1r3+tf75y5YqerDltyfvWt76FX/7yl/rn7373u9iwYUPZ45tf+tKXsGvXLtx777340Y9+VLb+xx9/bDqmXiXXSV5/fz+GhoZqboXbs2dP2edz585B0zTbcfIkSTJ8588o81UUBQMDA3rHKyWV7/QBK+NNWFXOQ/fciTMF45u599//o+XNXD1qa0K2T5LXgvMY1yc+gDF6pb1idMaqbjiz+B7unTa+aX1s54eexrFae9ULAGM0xxi90ch6wY71e1rWN6V2vDrOtfyWGKM3rpYYzcoLUCozx3HsP99rON9JBzZuYnzllVdw/fXXo6+vD2+99Zbl+HZmtm/fjm984xu4/vrrsWXLFpw5c6bssdN4PA6/349du3Zh165dOHTokL4sAPz4xz92vC/XSd7CwgKA8ozeSe+aL774IsbGxvTPoihidHTUdn+VLXCqqiIUCukteYqiQBAEiKIIURQRi8X0ZWVZxvDwsKuOWM4U3sW908an6bGdf6p5e0RERHT1YUcXRM5ZlRdg/crM6oHJ3Xr22WdNW+Mq3zN85ZVXXO/HdZLX29uLUCiE7u5uZDIZyLJclliZicVihsMoOJFKpRCNRtHf349sNls29t3U1BT6+/sxMTEBQRAQCoUwMzMDQRCQz+c5Th4REREREV0VXCd5AwMDSKVSiMfjKBaLSCQS6O3ttV0vFAphz549CIfD6OzsxPz8PEKhkG2HLQDKWuiGh4fL5lUmccFg0HRoBSIiIiIionZl/qavjRMnTqCnpwfT09OYnJyEqqo4ceKE7XrJZBJnz37yjO2OHTssBzUnIiIiIiIi51wneasTs66uLgwNDTlK1rq7uzE9Pe2o5Y6IiIiIiIhqU9PjmufPn0cymYTP50Mmk6man8vlcN9991lu48iRIxgcHMTWrVv1aU46bCEiIiIiIiJ7NSV5XV1dkCQJsVgM+XwePT09ZfMnJiZstxGJRNDb24tAIABBEKAoiuHQCERERERERFS7mjte6enpwb59+zA3N+eql8yenh7kcjkkk0lomobp6emqZJGIiIiIiIjccf1O3sDAAJ5++ml9zLu5uTlcuHDBdr3z589j//79GBsbw/e//30sLCw4Wo+IiIiIiIjsuU7yJicnIQgCJEkCsJL0Oel4hb1rEhERERERrR3X4+SFQiEMDQ1hbm6upvW6u7sxPj7udrdERERERERkwXVL3sLCAgDA5/Pp07LZrO16R44cwcWLF8umOVmPiIiIiIiI7Lluyevt7UUoFEJ3dzcymQxkWUYsFrNdj71rEhERERERrZ26Ol5JJpPo7e1FsVhEIpHAjh07bNcr9a45PDyMUCiEQ4cOOVqPiIiIiIiI7LluyQMAURQxPT1d83pdXV1l7+U9//zztoOoExERERERkb2ak7wLFy4gkUggm81C0zT09fUhEongC1/4gqsA5ufnEY/HmeQREREREXlg6J47cabwrun8997/IzobGA81Xk1J3tNPP41oNIpgMAhRFNHV1YVDhw4hHo8jEongqaeecrSd+fl5pFIpJJNJLC4uYtu2ba6CJyIiIiKicmcK7+LeafPb/Md2/qmB0dB6cJzkHThwANlsFouLi+jq6qqaf//99+PgwYO4++67DdevTOwCgQASiQSGhoawf/9+90dAREREtM7YckJUG6syw/JSP8dJnizLSCaTpvP37duHBx54oCrJ2717N/bv3w9N0yBJUlliNzQ0BACOx81TVRXpdBqiKEJVVYTDYQiCUPeyRERERPVohZaTVkhEGePVw6rMNEN5aXWOkzxRFF0tMzY2Bk3TIAgC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",
      "text/plain": [
       "<Figure size 900x300 with 9 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def plot_contiguous_edit_sweep(axes, df, name_idx, delta_idx, delta, label):\n",
    "    colors = ['yellowgreen', 'tab:blue', 'lightsalmon', 'dimgrey',]\n",
    "    markers = '^osv'\n",
    "\n",
    "    edit_types = sorted(set(df.index.get_level_values(0)))\n",
    "    config_key = df.index.names[1]\n",
    "    config_vals = np.array(sorted(set(df.index.get_level_values(1)))[1:])\n",
    "    metrics = [\n",
    "        (\"edit_detection.t2\", \"Detection\\nAccuracy\",),\n",
    "    ]\n",
    "    edit_type_to_range = {\n",
    "        \"INSERT\": (0, 1.05),\n",
    "        \"REPLACE\": (0, 1.05),\n",
    "        \"REMOVE\": (0, 1.05),\n",
    "    }\n",
    "    bar_w=.18\n",
    "    for metric_idx, (metric, metric_name) in enumerate(metrics):\n",
    "        for type_idx, (type, ylim) in enumerate(edit_type_to_range.items()):\n",
    "            plt.sca(axes[type_idx])\n",
    "            if delta_idx == 0: plt.title(type.replace(\"REMOVE\", \"DELETE\"), fontsize='smaller')\n",
    "            if delta_idx == 2: plt.xlabel(f\"Edit length\")\n",
    "            if type_idx == 0:\n",
    "                plt.ylabel(metric_name)\n",
    "            if type_idx == 2:\n",
    "                ax = plt.gca()\n",
    "                ax.text(1.05, 0.5, f'$\\\\delta$={delta}', rotation='horizontal', ha='left', va='center', transform=ax.transAxes)\n",
    "            ys = 1-df[df.index.get_level_values('edits.type') == type][metric][1:]\n",
    "            plt.bar(config_vals+bar_w*name_idx-bar_w*3/2, ys, bar_w, linewidth=.5, linestyle='-',\n",
    "                     alpha=1, color=colors[name_idx], label=label, edgecolor='black', zorder=100)\n",
    "            plt.yticks([0, .5, 1], labels=None if type_idx == 0 else [])\n",
    "            if metric_idx >= 2: plt.ylim(-.25, 0.0)\n",
    "            else: plt.ylim(*ylim)\n",
    "            plt.xlim(min(config_vals)-bar_w*2-.05, max(config_vals)+2*bar_w+.05)\n",
    "            if metric_idx == len(metrics) - 1: plt.xticks(config_vals)\n",
    "            else: plt.xticks(config_vals, labels=[])\n",
    "            plt.grid(True, alpha=.5)\n",
    "            plt.gca().spines['top'].set_visible(False)\n",
    "            plt.gca().spines['right'].set_visible(False)\n",
    "            plt.gca().spines['left'].set_visible(False)\n",
    "            plt.tight_layout()\n",
    "\n",
    "fig, axes = plt.subplots(3, 3, sharex=True, figsize=(9, 3))\n",
    "for name_idx, (name, vals) in enumerate(name_to_data.items()):\n",
    "    for delta_idx, (df, delta) in enumerate(vals):\n",
    "        plot_contiguous_edit_sweep(axes[delta_idx], df, name_idx, delta_idx, delta, name)\n",
    "plt.legend(ncol=2, loc='center', bbox_to_anchor=(-.5, -1.4))\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.subplots_adjust(hspace=.5, wspace=.1)\n",
    "plt.savefig(f'15_llama_delta_comparison.pdf', dpi=300, bbox_inches='tight', pad_inches=.05)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "c4eee131",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_11266/61456035.py:47: UserWarning: Tight layout not applied. tight_layout cannot make Axes width small enough to accommodate all Axes decorations\n",
      "  plt.tight_layout()\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 900x300 with 9 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def plot_contiguous_edit_sweep(axes, df, name_idx, delta_idx, delta, label):\n",
    "    colors = ['yellowgreen', 'tab:blue', 'lightsalmon', 'dimgrey',]\n",
    "    markers = '^osv'\n",
    "\n",
    "    edit_types = sorted(set(df.index.get_level_values(0)))\n",
    "    config_key = df.index.names[1]\n",
    "    config_vals = np.array(sorted(set(df.index.get_level_values(1))))\n",
    "    metrics = [\n",
    "        (\"diff.wm_detection.scores\", \"Watermark\\nScore\"),\n",
    "    ]\n",
    "    edit_type_to_range = {\n",
    "        \"INSERT\": (0, 1.05),\n",
    "        \"REPLACE\": (0, 1.05),\n",
    "        \"REMOVE\": (0, 1.05),\n",
    "    }\n",
    "    bar_w=.18\n",
    "    for metric_idx, (metric, metric_name) in enumerate(metrics):\n",
    "        for type_idx, (type, ylim) in enumerate(edit_type_to_range.items()):\n",
    "            plt.sca(axes[type_idx])\n",
    "            if delta_idx == 0: plt.title(type.replace(\"REMOVE\", \"DELETE\"), fontsize='smaller')\n",
    "            if delta_idx == 2: plt.xlabel(f\"Edit length\")\n",
    "            if type_idx == 0:\n",
    "                plt.ylabel(metric_name)\n",
    "            if type_idx == 2:\n",
    "                ax = plt.gca()\n",
    "                ax.text(1.05, 0.5, f'$\\\\delta$={delta}', rotation='horizontal', ha='left', va='center', transform=ax.transAxes)\n",
    "            ys = df[df.index.get_level_values('edits.type') == type][metric]\n",
    "            plt.bar(config_vals+bar_w*name_idx-bar_w*3/2, ys, bar_w, linewidth=.5, linestyle='-',\n",
    "                     alpha=1, color=colors[name_idx], label=label, edgecolor='black', zorder=100)\n",
    "            plt.yticks([-.2, -.1, 0], labels=None if type_idx == 0 else [])\n",
    "            plt.ylim(-.225, 0)\n",
    "            plt.xlim(min(config_vals)-bar_w*2-.05, max(config_vals)+2*bar_w+.05)\n",
    "            if metric_idx == len(metrics) - 1: plt.xticks(config_vals)\n",
    "            else: plt.xticks(config_vals, labels=[])\n",
    "            plt.grid(True, alpha=.5)\n",
    "            plt.gca().spines['top'].set_visible(False)\n",
    "            plt.gca().spines['right'].set_visible(False)\n",
    "            plt.gca().spines['left'].set_visible(False)\n",
    "            plt.tight_layout()\n",
    "\n",
    "fig, axes = plt.subplots(3, 3, sharex=True, figsize=(9, 3))\n",
    "for name_idx, (name, vals) in enumerate(name_to_data.items()):\n",
    "    for delta_idx, (df, delta) in enumerate(vals):\n",
    "        plot_contiguous_edit_sweep(axes[delta_idx], df, name_idx, delta_idx, delta, name)\n",
    "plt.legend(ncol=2, loc='center', bbox_to_anchor=(-.5, -1.4))\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.subplots_adjust(hspace=.5, wspace=.1)\n",
    "plt.savefig(f'15_llama_delta_comparison_wm.pdf', dpi=300, bbox_inches='tight', pad_inches=.05)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0ff0bf7f",
   "metadata": {},
   "source": [
    "# Figure 6: Watermark Detection"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "cef43b39",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Namespace(model='meta-llama/Llama-2-7b-hf') 16_Llama-2-7b-hf_randACADBCBD_ppl.pkl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loading checkpoint shards: 100%|██████████| 2/2 [00:14<00:00,  7.31s/it]\n",
      "batch_idx=0, watermark.delta=4.5 GENERATEING:  18%|█▊        | 3/17 [00:26<02:03,  8.81s/it]▌         | 1/17 [00:08<02:16,  8.53s/it]_idx=0 DONE:  12%|█▏        | 2/17 [00:17<02:10,  8.70s/it]ch_idx=0 DONE:  18%|█▊        | 3/17 [00:26<02:03,  8.81s/it]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "batch_idx=0 DONE: 100%|██████████| 17/17 [02:35<00:00,  9.33s/it]                           ch_idx=0 DONE:  24%|██▎       | 4/17 [00:35<01:55,  8.89s/it]atch_idx=0 DONE:  29%|██▉       | 5/17 [00:44<01:46,  8.91s/it]atch_idx=0 DONE:  35%|███▌      | 6/17 [00:53<01:38,  8.98s/it]] ] it]]  t]t]  2s/it]/it]  s/it]s/it]     5s/it]/it]  s/it]s/it]     9.18s/it]18s/it]  .18s/it].18s/it]        0s/it]/it]  s/it]s/it]       9.22s/it]9.22s/it]   9.22s/it] 9.22s/it]          ,  9.24s/it] 9.24s/it]    9.24s/it]  9.24s/it]           8,  9.26s/it]  9.26s/it]  ,  9.26s/it],  9.26s/it]            ,  9.30s/it] 9.30s/it]    9.30s/it]  9.30s/it]           tch_idx=0 DONE: 100%|██████████| 17/17 [02:35<00:00,  9.13s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "    batch_idx   val  detection.threshold  ...  detection.t2  ppl.base  ppl.wmked\n",
      "16          0     0                  0.0  ...      1.000000  4.068985   4.068985\n",
      "15          0  0.25                  0.0  ...      1.000000  4.068985   4.205578\n",
      "14          0   0.5                  0.0  ...      1.000000  4.068985   4.239930\n",
      "13          0  0.75                  0.0  ...      0.992188  4.068985   4.302799\n",
      "12          0     1                  0.0  ...      0.945312  4.068985   4.563266\n",
      "11          0  1.25                  0.0  ...      0.875000  4.068985   4.810239\n",
      "10          0   1.5                  0.0  ...      0.843750  4.068985   5.105776\n",
      "9           0  1.75                  0.0  ...      0.710938  4.068985   5.618892\n",
      "8           0   2.0                  0.0  ...      0.562500  4.068985   6.096967\n",
      "7           0   2.5                  0.0  ...      0.257812  4.068985   7.230116\n",
      "6           0   3.0                  0.0  ...      0.148438  4.068985   8.308507\n",
      "5           0   3.5                  0.0  ...      0.070312  4.068985   9.854684\n",
      "4           0   4.0                  0.0  ...      0.007812  4.068985  11.188523\n",
      "3           0   4.5                  0.0  ...      0.000000  4.068985  12.704164\n",
      "2           0   5.0                  0.0  ...      0.000000  4.068985  13.862586\n",
      "1           0   5.5                  0.0  ...      0.000000  4.068985  15.622605\n",
      "0           0   6.0                  0.0  ...      0.000000  4.068985  16.417177\n",
      "\n",
      "[17 rows x 7 columns]\n",
      "Namespace(model='meta-llama/Llama-2-7b-hf') 16_Llama-2-7b-hf_randAB_ppl.pkl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "batch_idx=0 DONE: 100%|██████████| 17/17 [02:37<00:00,  9.26s/it]                           ▌         | 1/17 [00:09<02:26,  9.13s/it]_idx=0 DONE:  12%|█▏        | 2/17 [00:18<02:17,  9.17s/it]ch_idx=0 DONE:  18%|█▊        | 3/17 [00:27<02:08,  9.19s/it]ch_idx=0 DONE:  24%|██▎       | 4/17 [00:36<01:59,  9.21s/it]atch_idx=0 DONE:  29%|██▉       | 5/17 [00:46<01:50,  9.21s/it]atch_idx=0 DONE:  35%|███▌      | 6/17 [00:55<01:41,  9.25s/it]] ] it]]  t]t]  8s/it]/it]  s/it]s/it]     9s/it]/it]  s/it]s/it]     9.27s/it]27s/it]  .27s/it].27s/it]        9s/it]/it]  s/it]s/it]       9.29s/it]9.29s/it]   9.29s/it] 9.29s/it]          ,  9.27s/it] 9.27s/it]    9.27s/it]  9.27s/it]           8,  9.26s/it]  9.26s/it]  ,  9.26s/it],  9.26s/it]            ,  9.25s/it] 9.25s/it]    9.25s/it]  9.25s/it]           \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "    batch_idx   val  detection.threshold  ...  detection.t2  ppl.base  ppl.wmked\n",
      "16          0     0               0.5625  ...      0.906250  4.068985   4.068985\n",
      "15          0  0.25               0.5625  ...      0.812500  4.068985   3.926525\n",
      "14          0   0.5               0.5625  ...      0.781250  4.068985   4.216709\n",
      "13          0  0.75               0.5625  ...      0.585938  4.068985   4.406190\n",
      "12          0     1               0.5625  ...      0.460938  4.068985   4.492677\n",
      "11          0  1.25               0.5625  ...      0.296875  4.068985   4.611147\n",
      "10          0   1.5               0.5625  ...      0.171875  4.068985   5.023189\n",
      "9           0  1.75               0.5625  ...      0.101562  4.068985   5.189120\n",
      "8           0   2.0               0.5625  ...      0.046875  4.068985   5.450252\n",
      "7           0   2.5               0.5625  ...      0.015625  4.068985   6.039668\n",
      "6           0   3.0               0.5625  ...      0.000000  4.068985   6.629443\n",
      "5           0   3.5               0.5625  ...      0.000000  4.068985   7.024257\n",
      "4           0   4.0               0.5625  ...      0.000000  4.068985   7.389698\n",
      "3           0   4.5               0.5625  ...      0.000000  4.068985   7.743952\n",
      "2           0   5.0               0.5625  ...      0.000000  4.068985   8.245586\n",
      "1           0   5.5               0.5625  ...      0.000000  4.068985   8.790439\n",
      "0           0   6.0               0.5625  ...      0.000000  4.068985   9.374562\n",
      "\n",
      "[17 rows x 7 columns]\n",
      "Namespace(model='meta-llama/Llama-2-7b-hf') 16_Llama-2-7b-hf_randAA_ppl.pkl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "batch_idx=0 DONE: 100%|██████████| 17/17 [02:38<00:00,  9.38s/it]                           ▌         | 1/17 [00:09<02:27,  9.22s/it]_idx=0 DONE:  12%|█▏        | 2/17 [00:18<02:18,  9.25s/it]ch_idx=0 DONE:  18%|█▊        | 3/17 [00:27<02:09,  9.27s/it]ch_idx=0 DONE:  24%|██▎       | 4/17 [00:37<02:00,  9.27s/it]atch_idx=0 DONE:  29%|██▉       | 5/17 [00:46<01:51,  9.31s/it]atch_idx=0 DONE:  35%|███▌      | 6/17 [00:55<01:42,  9.30s/it]] ] it]]  t]t]  3s/it]/it]  s/it]s/it]     3s/it]/it]  s/it]s/it]     9.34s/it]34s/it]  .34s/it].34s/it]        9s/it]/it]  s/it]s/it]       9.37s/it]9.37s/it]   9.37s/it] 9.37s/it]          ,  9.35s/it] 9.35s/it]    9.35s/it]  9.35s/it]           8,  9.34s/it]  9.34s/it]  ,  9.34s/it],  9.34s/it]            ,  9.33s/it] 9.33s/it]    9.33s/it]  9.33s/it]           tch_idx=0 DONE: 100%|██████████| 17/17 [02:38<00:00,  9.34s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "    batch_idx   val  detection.threshold  ...  detection.t2  ppl.base  ppl.wmked\n",
      "16          0     0                0.375  ...      0.859375  4.068985   4.068985\n",
      "15          0  0.25                0.375  ...      0.664062  4.068985   4.157000\n",
      "14          0   0.5                0.375  ...      0.320312  4.068985   4.255521\n",
      "13          0  0.75                0.375  ...      0.132812  4.068985   4.343813\n",
      "12          0     1                0.375  ...      0.054688  4.068985   4.461768\n",
      "11          0  1.25                0.375  ...      0.007812  4.068985   4.490460\n",
      "10          0   1.5                0.375  ...      0.015625  4.068985   4.628824\n",
      "9           0  1.75                0.375  ...      0.007812  4.068985   4.777449\n",
      "8           0   2.0                0.375  ...      0.007812  4.068985   5.068827\n",
      "7           0   2.5                0.375  ...      0.007812  4.068985   5.455634\n",
      "6           0   3.0                0.375  ...      0.000000  4.068985   5.909021\n",
      "5           0   3.5                0.375  ...      0.000000  4.068985   6.472131\n",
      "4           0   4.0                0.375  ...      0.000000  4.068985   6.849866\n",
      "3           0   4.5                0.375  ...      0.000000  4.068985   7.140776\n",
      "2           0   5.0                0.375  ...      0.000000  4.068985   7.516020\n",
      "1           0   5.5                0.375  ...      0.000000  4.068985   7.652687\n",
      "0           0   6.0                0.375  ...      0.000000  4.068985   8.074280\n",
      "\n",
      "[17 rows x 7 columns]\n",
      "Namespace(model='meta-llama/Llama-2-7b-hf') 16_Llama-2-7b-hf_fixedAA (fixed)_ppl.pkl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "batch_idx=0 DONE: 100%|██████████| 17/17 [02:26<00:00,  8.63s/it]                           ▌         | 1/17 [00:08<02:15,  8.45s/it]_idx=0 DONE:  12%|█▏        | 2/17 [00:16<02:07,  8.48s/it]ch_idx=0 DONE:  18%|█▊        | 3/17 [00:25<01:59,  8.51s/it]ch_idx=0 DONE:  24%|██▎       | 4/17 [00:34<01:51,  8.57s/it]atch_idx=0 DONE:  29%|██▉       | 5/17 [00:42<01:43,  8.65s/it]atch_idx=0 DONE:  35%|███▌      | 6/17 [00:51<01:35,  8.67s/it]] ] it]]  t]t]  5s/it]/it]  s/it]s/it]     4s/it]/it]  s/it]s/it]     8.63s/it]63s/it]  .63s/it].63s/it]        3s/it]/it]  s/it]s/it]       8.62s/it]8.62s/it]   8.62s/it] 8.62s/it]          ,  8.63s/it] 8.63s/it]    8.63s/it]  8.63s/it]           7,  8.64s/it]  8.64s/it]  ,  8.64s/it],  8.64s/it]            ,  8.65s/it] 8.65s/it]    8.65s/it]  8.65s/it]           \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "    batch_idx   val  detection.threshold  ...  detection.t2  ppl.base  ppl.wmked\n",
      "16          0     0             0.328125  ...      0.875000  4.068985   4.068985\n",
      "15          0  0.25             0.328125  ...      0.742188  4.068985   3.859520\n",
      "14          0   0.5             0.328125  ...      0.539062  4.068985   3.993583\n",
      "13          0  0.75             0.328125  ...      0.406250  4.068985   3.989031\n",
      "12          0     1             0.328125  ...      0.226562  4.068985   4.220685\n",
      "11          0  1.25             0.328125  ...      0.195312  4.068985   4.220536\n",
      "10          0   1.5             0.328125  ...      0.070312  4.068985   4.366977\n",
      "9           0  1.75             0.328125  ...      0.046875  4.068985   4.584762\n",
      "8           0   2.0             0.328125  ...      0.015625  4.068985   4.885772\n",
      "7           0   2.5             0.328125  ...      0.000000  4.068985   5.452030\n",
      "6           0   3.0             0.328125  ...      0.000000  4.068985   6.189699\n",
      "5           0   3.5             0.328125  ...      0.000000  4.068985   6.787204\n",
      "4           0   4.0             0.328125  ...      0.000000  4.068985   7.448503\n",
      "3           0   4.5             0.328125  ...      0.000000  4.068985   8.140778\n",
      "2           0   5.0             0.328125  ...      0.000000  4.068985   8.698411\n",
      "1           0   5.5             0.328125  ...      0.000000  4.068985   9.197686\n",
      "0           0   6.0             0.328125  ...      0.000000  4.068985   9.889024\n",
      "\n",
      "[17 rows x 7 columns]\n"
     ]
    }
   ],
   "source": [
    "%%bash\n",
    "for model in \"meta-llama/Llama-2-7b-hf\"; do python 16_exp_wm_detection_vs_ppl.py --model=\"$model\"; done"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "9664cbfd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "dict_keys(['./16_Llama-2-7b-hf_fixedAA (fixed)_ppl.pkl', './16_Llama-2-7b-hf_randAA_ppl.pkl', './16_Llama-2-7b-hf_randAB_ppl.pkl', './16_Llama-2-7b-hf_randACADBCBD_ppl.pkl', './16_opt-2.7b_fixedAA (fixed)_ppl.pkl', './16_opt-2.7b_randAA_ppl.pkl', './16_opt-2.7b_randAB_ppl.pkl', './16_opt-2.7b_randACADBCBD_ppl.pkl'])"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from utils import *\n",
    "import pickle\n",
    "\n",
    "dfs = {}\n",
    "total_name = f\"16_*.pkl\"\n",
    "for idx, filename in enumerate(sorted(glob.glob(os.path.join(\".\", total_name)))):\n",
    "    with open(filename, 'rb') as file:\n",
    "        df = pickle.load(file)\n",
    "    dfs[filename] = df\n",
    "dfs.keys()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d3674c99",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_11266/2209169407.py:16: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  (df[\"ppl.wmked\"][i], df[y_key][i]),\n",
      "/tmp/ipykernel_11266/2209169407.py:16: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  (df[\"ppl.wmked\"][i], df[y_key][i]),\n",
      "/tmp/ipykernel_11266/2209169407.py:16: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  (df[\"ppl.wmked\"][i], df[y_key][i]),\n",
      "/tmp/ipykernel_11266/2209169407.py:16: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  (df[\"ppl.wmked\"][i], df[y_key][i]),\n",
      "/tmp/ipykernel_11266/2209169407.py:16: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  (df[\"ppl.wmked\"][i], df[y_key][i]),\n",
      "/tmp/ipykernel_11266/2209169407.py:16: FutureWarning: Series.__getitem__ treating keys as positions is deprecated. In a future version, integer keys will always be treated as labels (consistent with DataFrame behavior). To access a value by position, use `ser.iloc[pos]`\n",
      "  (df[\"ppl.wmked\"][i], df[y_key][i]),\n",
      "/tmp/ipykernel_11266/2209169407.py:66: UserWarning: Tight layout not applied. The left and right margins cannot be made large enough to accommodate all Axes decorations.\n",
      "  plt.tight_layout()\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 650x250 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAf8AAABBCAYAAADfRq0PAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjMsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvZiW1igAAAAlwSFlzAAAPYQAAD2EBqD+naQAAF61JREFUeJztnVuMG9d5x//kXiKtZXvMtWU1dRRrprkAQfzAXQUR0KRBNUofWuSlHBEwAvQly0Ee9BSUg9VDUSCA6WFfDQQcFUUf2gK7ZF/aFAnK2aJFLwqs5RgpbD0Y4ShxHFmxLZK2ZO16L5w+sOfscDhX3rSX7wcsJM6c+c53Zs73fec2c1KO4zggCIIgCOLEkH7cChAEQRAEMV0o+BMEQRDECYOCP0EQBEGcMCj4EwRBEMQJg4I/QRAEQZwwKPgTBEEQxAmDgj9BEARBnDBmk16wv7+P3d3dSehCEARBEMSQzM/PI52O16ePHfwdx8G9e/fQ6XSG1YsgCIIgiAmRTqdx4cIFzM/PR6ZNxf3C33vvvYdOp4OzZ89iYWEBqVRqZEUJgiAIghidbreLu3fvYm5uDufPn4+M0bF6/vv7+zzwLy4ujkVRgiAIgiDGx3PPPYe7d+9ib28Pc3NzoWljTQ6wOf6FhYXRtSMIgiAIYuyw4f79/f3ItIlW+9NQP0EQBEEcTpLEaHrVb4zQYkiCGB6yH4KYHicm+FuWBU3TxpbOi2EYaLVasCwLqqoilUpB0zRYlgUAsG0biqJAkiQYhhFL5tLSEmq1WmJdpoFpmpAkaeL6maaJpaWlvns2rvtSLpdHljFVul3gng3YP+/92+1OLesgu/DWd8MwUC6XoShKomfE7Md7jMms1WowTROGYcC27ZHLw4hTjw+bHcbVx8923Pg9O03ToCgKTNMct9pj48jZ7WHFicHW1pZz+/ZtZ2trK07yUN796GfO+lt/6rz70c9GlpWEQqHgCIIwtnRuGo2GU61W+e9ms+kAcNrt9kBaXddjy63X674yDguFQqGv3JNC13WnUqnw3+O6L+122ykWiyPLmQq/fNNx1l91nL+9fvC3/mrv+BQIs4t2uz1Q39mxer0eKdtrP47jOLIs9z1zlg6A02w2kxcghKh6PG47HFVWEn28tuOnS9CzazQasfLw02WSfutI2e2USRKrp9rzdxwHr999DZ3tO3j97mtw4r1lOBYEQUCn04ls0cZN56ZUKiGXy/HfmUwmVH5cZFlOlH7aPC7dxnVfmIxx9iQnwq/eAv79H4BHH/cff/Rx7/iv3pq4CnHswv1MBEFANptFtVqNlO21H9azKxQKfemy2ezAsXEQVZfGaYe2bWN9fX0kGZP2C4IgQBRFrK2tRab1K884yhjGkbHbQ85Ug/+7D27iw0e3AQAfPrqNdx/cnEq+pmkin89DluVQZxQ3nZtOpwNRFMelKjFl8vn8oRrSHaDbBV7/cXia1/9lolMAw9oFm+qKSue1n1KpBFVVfdNHyTvs6Lr+uFWIRavVgiRJken8yjONMh56uz0CJP68r5f//e3f4c33/x4A8K0Xf4jPPrnMz3386W/w47e/BwA4//S38MGjN5FCGg66SCGNf7uzitnUaaRSKbz81Z/0yX37/j9h8+6PAACXXvhzXHjmD4fW0bIsFItFqKqKlZUVVCqVkdK5WV9fx8WLFxPrZJomNE2DqqoQRRG2baNer3PnalkWVlZWoKoq7+3UajXYtg1BENBoNKAoCizLQjabhaqqfE62Uqmg0WigVqtBEATYto1ms8mNMihvXdd5767ZbMYqf71e573CW7duYXV1lbfMg/LvdDpYX1+HKIr8Ol3XYZomLMuCKIr8mBfvfYm6j6y8QXKz2Sw0TUOxWEz8DEfmrf8Cbv937//fUIBzriD4oAX89Aawvwd8+ihczqOPgPd/eXD9LyzgjXrv/1/7E+DzXxlJzbh24X7e9XodGxsbyGazobK99mPbdmiDWpblPr1M0+TPPZfLQRTFoep3UD0epr6F2d3m5iZf2yDLMkRRDC2H165v3Ljh6xf88huGTqeDUqkEWZYj5fuVx7Zt3zL62aBf+XRdj7y/wGO222PCyMF/d/8TfLL7PgBg39npO+c4XX6us23zXj8AOOhiZ/8hdvDQX253m1+7190eVU0AQC6X44tZ3E5k2HQA0Gw2sby8HJrGD1mWIctyX8WuVqs8mGezWeTzeZ6+0+lgZWUF7XYbACBJEjRN4/rJsoxGo4FKpcKnHRRFQbPZhCzLUFUVtVoNuVwuMO9arYZisYhsNgtJktDpdCKHFyVJ4joIggBFUVCv10PzNwwD2WyWX9dqtWDbNjRNQ6PR4MfK5fKAcXvvS9R9jCPXu9Bsaux+ejCU730v13EGh/nDePTg4P97OwfX7o1vH44ou3AP3YuiCE3TUKlUQkfGhrUf9lxZXQN6C+E2NjaGqt9B9ThpfQOi7U6SJB5Y45TDbddefcLyS4JhGPw5scAbJd+vPKIoBpbRzwa95YtzfxmPzW6PCSMH/7mZJ/DE3FkAwEyq/3vCqVQaT8ydheM4aG83ea/fTRqzODX7zKDc9CkudzZ9amj9WCufrXgVRRHVanXAecVN5yUsQLZarYFz7teZFhcX+76YKAjC0BVaEAQuixl+u93mLXYWYMPydhs80yUq+LvPy7KMK1eu8HsSlH8ul8PS0hJEUUQ+n0ehUECpVEImk+mbU75161assofdR+ZUhpE7ceY+Ayw81fv/zEz/uVSqdy5Ozx8AFp48+P/s/IHc2fCvfEUxrF3IsoxKpQJVVfsCmxev/bA6aNu276iBbdvIZDKoVCoD50VRxPr6OgqFQuL6HVaPvUTZbZjdeYkqh59de0mSXxAsr0nID7NBv/KN0y8SwYwc/F96/rt46fnv+p576jO/i5e/+hP8+uP/wU9/cc03TRd7+OaLfzFw/IuL38EXF78zqnqwLKtveC+TyfgOXcZN54UNFXqPMWNxO5wghxYHQRBQKBRQLpchCMJA6xzAwO9SqYTFxUU+jBgnj3ESlH8mk0G73YZlWVhbW4OiKHy0wx1UxrW4a1JyR+Yrv9/78+PJDKBovbn8f/yr8FGAhaeBsy8e/P69bO9vDAxrFwBw8eJFlEql0DR+9lMsFlGpVHyDnWVZiXu17rymQVy7i/tdgyjbTWrnSUlSnqDOTpgN0pqpx8PEF/w5jvP/c/dBXx5KYfPuj6a28j+Xy8VazR83nSRJvi1hXdcH5qlqtVpkj8mLd6SgWCyiUCj4znW5W8dsjq1YLPK5dXY8Tl7D6GdZFl+JHJZ/qVTiDSFd1yEIAvL5/IBu7t9e3eLqGiUXCH8747GTTvfm7cP42h/30k2BuHYB9ObRr169GprGz37YnLL3/XT3M/d7rpZlheYXVmeC6nGca90ksTu2kDKqHH69XrfcqPzi6B7Us05aHr9jUTY4bK/+UNvtEWDknn8UXWcXn+zcAxAU3B18svNbdJ3dgWmDUTBNE7quo9VqQZZl3uM2DAOCIPQtKomTLqi3yIY3vb2RQqHAP5rB5hfdMlivl8mwbZv3spiRra2tIZPJ8BZ3s9mEJEkQBAGZTAaKovBFSO4FNbIsY3l5mQdhoDdvx2QH5Q30WuimacK2bei6zoNzEGxRTqfTwebmJm/whOW/uLgI0zSRyWTQarWQz+d5Q0DTNL4ATJblAV0B9N0Xdp+C7mOQXPdzuHLlSmD5DgWf/wrwrZd7q/7dIwALT/cC/4gL+vyIaz/Ly8t8FMBd12/dugVRFCNHCILsp16vo1wuc5nM0bN07LmWy2W+iKxarfJFeknqNxBcj5msuPUtrN4Dvfl0XddhGAZfDBdUDj+79uqTxM69o47u87quQ1XVgTRJyxNWRq8NhpUv6P6yfI+E3R5yYm3pu729jTt37uDChQs4dSr5/PvDnXvY3msHnj81m8GZ+ecTyz0sKIoS+xWoYXG3wIGDRTSqqiYeTSAOcDcCDz3dbm9V/6MHvTn+sy9Orcc/SaZhP8Tx4kjZ7RRJEqsn3vMHgDPz53Bm/tw0snosDLvCNgn1er1vlS9bLEcfuhgeNoR5ZBxIOt3/OuAxYRr2QxwfjpzdHlKOfrfhECDLMlqt1kQ3JmHvxZbLZdRqNdRqNbRarcOzeO0IUiqVjsxHV44z07Af4vhAdjsepjLsf1KI8148QRD+kP0QxGgkidXU8x8j5LgIYnjIfghielDwJwiCIIgTBgV/giAIgjhhUPAnCIIgiBMGBX+CIAiCOGFQ8CcIgiCIEwYF/zFC7ykTBBEX8hfE42Qqwf9uZwtv/uajwL/3PtqauA6WZUHTtLGl82IYBlqtFizLgqqqSKVS0DSNf1Mc6H3GVJIkX/lsHwDDMFCr1WCaJgzD4F/wq9VqWFpawjPPPMM3PDFNkx8rl8tclqZpA8fcmKYJSZJQq9USlzMJTD/3Bi1LS0tjyTeobMeRVquFd955J/BvGtudxrGLqDocR57XfgzDQLlc5l8BjJNWUZTAOhamY1x5SXQMu1fe55bk/o1CHPsfl52Oi7j6+PkcN37PTtM0KIoSa7Oqx8VE/J0Tg62tLef27dvO1tZWnOR9bO/uOUs//Ffn89qPA/+Wf1h3tnf3EstOQqFQcARBGFs6N41Gw6lWq/x3s9l0ADjtdrsvna7rA8ccx3FkWXZ0XR+QCcBpNBr8WLVaHdCNpfNSqVRCdS4UCn06Twpd1/t0qdfrvvcgKe122ykWiyPLOezcv3/fuXbtmvP9738/8O/atWvO/fv3J6pHlF3IsjxQ51jdbDabieS1221f+8nlcgN24peWHavX64l1jCsviY5evP4irm7jJMr+x2WnjFFlJdHH63P8dAl6xm5/G4afLuO8X36y4/i7JLF64j3/+Zk0PiucRipgR99UCvgd4RTmZyarCts3PKp1Fzedm1Kp1Pddcr+tJg3DQLFYHPiQCWvRebfozWazA5/uZbuKuUcTWq0WBEHoaxXbto3l5eVQnR/XB1W8W6UOC5Nx3Pc2ePjwIfb29kLT7O3t4eHDhxPVI8wuWB321le/OhxHXhA3btyApmm+w+XuOiUIArLZbN9mQUl1jJI3jI4Mr78Y5v6NSpQNjstOgZ6Nrq+vjyRjnPr4IQgCRFHkOwqG4VeecZQxjEn4u4kH/1QqhR98+0sI+oiw4wA/+PaXkApqHYwBtqe0LMuhBhw3nZtOpxO5wYRhGIH7jJdKJaiq6ntOUZSBCi/Lcl8F7XQ6uHr1at8xy7IGtuY8juTz+UM1NHlcibKLqDqcVF4QLAgHDekyOp0ObNvuyzupjlHyhtXRz1+MottR4Kh8h7/VakGSpMh0fuWZRhnH7e9GDv5//Z82vv7KBr7+ygZuNu/3nft16xG+/soGitWfY/GJeaR94vtsOoVi9ecDx6ubv+Zyf/rmeyPpyIKhqqqhrbO46dysr6/zPar90DQNmqb5tlrZ/uFBjQe2F7Ybv/nMsDnOMOr1OkzTRK1WG+ituOcc3XOznU4HhmH0XQegb9OhoLlhy7L65uPc83MsL6+zC5ObzWZRr9cTl/uwsLGxgevXr+P69et4++23+859+OGHuH79Ol577bXEcm/evMnlvvHGGyPrGWYXw9ThYeyMwfa89+KurysrK9jY2OBbXQ+jY5i8YXUEBv1FEt0sy+K2UC6XeS8wyI7YOga2HsFLkP0PY6dB/sI0TWxubqJer/etXwgriyRJMAwDhmFgaWlpQJ+w/Iah0+lA0zTIssxHWpKUJ6iMfr7Lr3xx7i8wfn838pa+D7b3cO/jbQDAzn6379x+1+HnLokZ3LQHFybtdR389sGnA8e3dvf5tVu7+6OqCaA3bM4WdoQZctx0ANBsNgOH2EulElZXV2GaJjRNG0vr8OrVq1BVlTuNbDbLnYNpmlheXo49PCZJEi+fIAhQFIVXLkVR0Gw2Icty35arhmEgm83y61qtFmzbhqZpaDQa/Fi5XPadynBvSyzLMmRZRr1e5z3AarXKg0McudNY7DYptra2uMP1Du13u92hV4Pv7Ozwa3d2dkbQsJ8kdjFJeX73xT2MLooiNE1DpVIZetvXUeUFPbswfxEGswW3819aWuKNEj87qtVqKBaLyGazkCRpYOOkIPtPaqdAsL9g10qSxANrnLI0Gg1UKhVkMpkBfcLyS4JhGPx5qqra92yTlEcUxcAy+vkub/ni3F/GOP3dyD3/J0/N4txTp3DuqcF5+5l0ip/7wtkzeOmFp3nvP53qXfv8k5/BuacGdx86PTfDrz09NzO0fqZpotls8paWKIq+Q41x03kJ24lMVVUIgoBqtYpyudw3Vw8c7EftncdhLcVUKgVVVfscCRtWrNVqsG2by8jlcqhWq4kcqVtvWZZhmibPq91uQxRF2LbNAzzLR1EULC0toVwu4+rVq7wSm6bJ53CDej5eFhcX+3pCgiDwCj6K3KPA6dOnIQgCBEHA7Gx/OzydTkMQBJw5cyax3Pn5eS53fn5+JB2j7CKoDjNYIzWuvChs246c0mLzw6y3m1THKHmj6Oj1F3F1q1QqAzJFUeQjJ3525A5mbrtyH2N47d9LmJ0Cwf7Cj6iyCILAh9+DAnqS/IIoFArI5XLI5XIDjbpR5Yf5Lr/yRd3fSTByz/973xDxvW/4t4Y/l1nAz65f5r//4+0P8Gd/8zoAoOsAr72cxR988Tnfa5Xlz0FZ/tyo6sGyLFQqFf47k8lgZWWl71iSdF7YwiU/2MI/URRRLBZ5a9JNsVhEpVLpq+SsQrLhOm/jIp/PY21tDaurq33HVlZWcOXKlVB941IqlbC4uDhgGJlMBu12G5ZlYW1tDYqiIJvN9o0GAIOLl4ZlUnIPA5cvX8bly5d9zz377LN45ZVX8M477+DVV19NJPfSpUu4dOnSOFSMZRd+ddh9vfv4sHbGsG07VhC+ePEiSqXSUDrGkTesjn7+YlTdgpjmot4gf+El7mhW1AhL3PyGJUl5vPeZlTHMd01C56RM9SM/3/zCs3jphacBAC+98DS++YVnp5k9gIMV81GrjOOmkyRpoFXo12JjQ/7e9zV1XUer1RpYIBTW0szlcgNDQkzfJAbvNkTLsngPxzRNWJaFYrEIURR5OtM0USqVeM9G13UIgoB8Pj9wn9y/vQYf1wFEyQX836wgJoefXbC67a3DcZ5zXDsDeiNphUIhluOs1+t9i2xH0dFP3rA6+vmLOLr52YJlWaE6RZUtyP7jXs8I8xd+aeOUxc+HuuVG5RdH96CeddLy+B2L8l3D9urH6e9G7vknIZVKofhHX8Zf/vNbKP7Rlye+wp8FVlmWeaA0DAOCIEDTND7PEyddUI9TluW+Vru7Z1MqlZDP5/n8NdBbAHj//n2srq5yQ2s0GiiXy9A0DZIk8dEBFly9iKLo2yItFAqJ5k7ZsFan08Hm5iYffmXrBlhlVRSFz3cuLi7CNE1kMhm0Wi1ePl3XoWkaH7qSZZmPDrDfALC2toZMJsOdvvs8W6DE8gqSy7Asa2wjHYeVM2fOYHZ2NvR1v9nZ2aGmB8KIaz/MLur1el8dZk6K2UVcecvLy332w+aqm80mrly5EjiKwPLtdDq4desWRFEcGE2I0jGuPK+Nh+noxesv4urGbKFcLvMFhdVqFYIgDNgZsyN2nWmasG0buq73+ZQg+2fy4tppmL8Aeg0iXddhGAZfwBhUFjZMblkWn0v36hOWn/deeKcX3Od1XYeqqgNpkpYnrIxe3xVWvqD7617wOU5/l3KcoJfwDtje3sadO3dw4cIFnDo1OD9/0lEUJdG8JTEe3A2440yr1Qp9j//MmTM0AnKEIH9BDEMcf5ckVk+1539cGXa1KTE8bCjuuAd+oDfUR8H9+ED+gkjKJPwdbewzBmRZRqvVGvrVLCI5pVLpyHw8hCDckL8gkjIJf0fD/mMk6YI7giBOLuQviHGTJFZTz3+MkCETBBEX8hfE44SCP0EQBEGcMBIF/xgzBARBEARBPAaSxOhYwX9ubg4A8OjRo+E0IgiCIAhiorC9PGZmoj+JH+tVv5mZGQiCgPfffx8AsLCwMNEP9BAEQRAEEZ9ut4sPPvgACwsLA3uF+BH7Pf9z584BAG8AEARBEARxeEin0zh//nysznmsV/3c7O/vY3d3d2jlCIIgCIIYP/Pz80in4y3lSxz8CYIgCII42tCrfgRBEARxwqDgTxAEQRAnDAr+BEEQBHHCoOBPEARBECcMCv4EQRAEccKg4E8QBEEQJwwK/gRBEARxwvg/Xwqvl3+lFr4AAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 200x20 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def plt_watermark_sweep_single(\n",
    "        df, index, label, y_key, y_label, ppl_base, xlim, ylim,\n",
    "        annotation_alpha=.1, annotation_offset=(0, 10), alpha=1):\n",
    "    colors = ['yellowgreen', 'tab:blue', 'lightsalmon', 'dimgrey',]\n",
    "    markers = '^vos'\n",
    "\n",
    "    plt.axvline(ppl_base, linestyle='--',\n",
    "                color='tab:red', linewidth=1,)\n",
    "    plt.plot(df[\"ppl.wmked\"], df[y_key], alpha=alpha,\n",
    "             linewidth=2, marker=markers[index], linestyle=':',\n",
    "             label=label, color=colors[index])\n",
    "    \n",
    "    for i in range(len(df)):\n",
    "        plt.annotate(\n",
    "            df.index[i],\n",
    "            (df[\"ppl.wmked\"][i], df[y_key][i]),\n",
    "            textcoords=\"offset points\", xytext=annotation_offset, ha='center',\n",
    "            color='black', alpha=annotation_alpha)\n",
    "    if idx == 7: plt.ylabel(y_label)\n",
    "    plt.ylim(*ylim)\n",
    "    plt.axhline(0, color='black', linewidth=1)\n",
    "    plt.xlabel(\"PPL (better ←)\")\n",
    "    plt.xlim(*xlim)\n",
    "    plt.grid(True)\n",
    "def plt_watermark_sweep(dfs, index, labels=None, colors=None,\n",
    "                        annotation_alpha=1, alpha=1):\n",
    "    if labels is None: labels = [\"???\"] * len(dfs)\n",
    "    if colors is None: colors = [None] * len(dfs)\n",
    "    ppl_base = torch.tensor([df[\"ppl.base\"].mean() for df in dfs]).mean()\n",
    "    xlim = ppl_base-.25, (max([df[\"ppl.wmked\"].max() for df in dfs]) - 3)\n",
    "    annotation_offset = [5, 5]\n",
    "    for df, label, color in zip(dfs, labels, colors):\n",
    "        annotation_offset[0] *= -1\n",
    "        plt_watermark_sweep_single(\n",
    "            df, index, label, \"detection.t2\", \"Type II Error (better ←)\",\n",
    "            ppl_base, xlim, (0, .6), alpha=alpha,\n",
    "            annotation_alpha=annotation_alpha, annotation_offset=annotation_offset)\n",
    "    plt.tight_layout()\n",
    "\n",
    "plt.figure()\n",
    "fig, ax = plt.subplots(1, 2, figsize=(6.5, 2.5), sharey=True)\n",
    "for idx, (filename, df) in enumerate(dfs.items()):\n",
    "    if \"opt\" in filename:\n",
    "        plt.sca(ax[0])\n",
    "        plt.title(\"OPT-1.3b\")\n",
    "    else:\n",
    "        plt.sca(ax[1])\n",
    "        plt.title(\"Llama-2-7b\")\n",
    "    label = filename\n",
    "    label = label.split(\"_\")[-2]\n",
    "    label = label.replace(\"fixedAA (fixed)\", \"AA (Unigram baseline)\")\n",
    "    label = label.replace(\"randAA\", \"AA (KGW baseline)\")\n",
    "    label = label.replace(\"randAB\", \"AB (Combinatorial Pattern)\")\n",
    "    label = label.replace(\"randACADBCBD\", \"ACADBCBD (Combinatorial Pattern)\")\n",
    "    plt_watermark_sweep(\n",
    "        [df], idx % 4, [label],\n",
    "        annotation_alpha=0, alpha=1,\n",
    "    )\n",
    "    plt.ylim(0, .4)\n",
    "plt.savefig(\"16_PPL.pdf\", dpi=300)\n",
    "\n",
    "handles, labels = plt.gca().get_legend_handles_labels()\n",
    "plt.figure(figsize=(2, .2))\n",
    "plt.legend(handles, labels, ncol=2, loc='center')\n",
    "plt.gca().axis('off')\n",
    "plt.tight_layout()\n",
    "plt.savefig(f\"16_PPL.legend.pdf\", dpi=300, bbox_inches='tight', pad_inches=.01)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": ".venv",
   "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.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
