{
 "cells": [
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Mauve and coherence metrics exploration\n",
    "\n",
    "Notebook for doing some EDA on metrics"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "INPUT_DIR = \"/scratch/<username>/test/watermarking-root/input\"\n",
    "OUTPUT_DIR = \"/scratch/<username>/test/watermarking-root/output\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Basic imports\n",
    "import os\n",
    "\n",
    "from tqdm import tqdm\n",
    "from statistics import mean\n",
    "\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import torch\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "from matplotlib import rc\n",
    "rc('font', **{'family': 'serif', 'serif': ['Computer Modern']})\n",
    "rc('text', usetex=True)\n",
    "\n",
    "import cmasher as cmr"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "from datasets import load_from_disk"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Load the processed dataset/frame"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "# save_name = \"analysis_ds_<date>_pile\"\n",
    "\n",
    "save_dir = f\"{INPUT_DIR}/processed_datasets/{save_name}\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "raw_data = load_from_disk(save_dir)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### convert to pandas df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "df = raw_data.to_pandas()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Orig number of rows: 66194\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>idx</th>\n",
       "      <th>truncated_input</th>\n",
       "      <th>baseline_completion</th>\n",
       "      <th>orig_sample_length</th>\n",
       "      <th>prompt_length</th>\n",
       "      <th>real_completion_length</th>\n",
       "      <th>no_bl_gen_time</th>\n",
       "      <th>w_bl_gen_time</th>\n",
       "      <th>spike_entropies</th>\n",
       "      <th>no_bl_output</th>\n",
       "      <th>...</th>\n",
       "      <th>w_bl_num_toks_gend_eq_0</th>\n",
       "      <th>w_bl_whitelist_fraction</th>\n",
       "      <th>w_bl_blacklist_fraction</th>\n",
       "      <th>w_bl_hit_list</th>\n",
       "      <th>avg_spike_entropy</th>\n",
       "      <th>w_bl_exp_num_wl_tokens</th>\n",
       "      <th>w_bl_var_num_wl_tokens</th>\n",
       "      <th>exp_wl_coef</th>\n",
       "      <th>w_bl_exp_whitelist_fraction</th>\n",
       "      <th>w_bl_var_whitelist_fraction</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>66189</th>\n",
       "      <td>1629</td>\n",
       "      <td>The cast of the 90s TV show, Hip Hip Hurray, j...</td>\n",
       "      <td>ed the picture post as: Nostalgia#at its best....</td>\n",
       "      <td>319</td>\n",
       "      <td>119</td>\n",
       "      <td>200</td>\n",
       "      <td>2.813786</td>\n",
       "      <td>0.767504</td>\n",
       "      <td>[[0.10299381613731384, 0.3138567805290222, 0.2...</td>\n",
       "      <td>ed the post, \"No cast ever.... (sic).\"\\nHere's...</td>\n",
       "      <td>...</td>\n",
       "      <td>False</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>[False, False, False, False, False, False, Fal...</td>\n",
       "      <td>0.505296</td>\n",
       "      <td>26.275373</td>\n",
       "      <td>12.998542</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.505296</td>\n",
       "      <td>0.249972</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>66190</th>\n",
       "      <td>1631</td>\n",
       "      <td>Seated left to right are Viktor Averin, Sergei...</td>\n",
       "      <td>\"arguably the mightiest organised crime group...</td>\n",
       "      <td>1130</td>\n",
       "      <td>930</td>\n",
       "      <td>200</td>\n",
       "      <td>3.019276</td>\n",
       "      <td>1.591323</td>\n",
       "      <td>[[0.39239728450775146, 0.6695157289505005, 0.3...</td>\n",
       "      <td>\"the largest and most powerful mafia organisa...</td>\n",
       "      <td>...</td>\n",
       "      <td>False</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>[False, False, False, False, False, False, Fal...</td>\n",
       "      <td>0.531480</td>\n",
       "      <td>49.959114</td>\n",
       "      <td>23.406847</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.531480</td>\n",
       "      <td>0.249009</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>66191</th>\n",
       "      <td>1632</td>\n",
       "      <td>Does Age Predict Technology Adoption?\\nA commo...</td>\n",
       "      <td>than bound paper, ink and glue to younger or ...</td>\n",
       "      <td>886</td>\n",
       "      <td>686</td>\n",
       "      <td>200</td>\n",
       "      <td>1.283562</td>\n",
       "      <td>3.061106</td>\n",
       "      <td>[[0.11953060328960419, 0.625767171382904, 0.38...</td>\n",
       "      <td>than that of a traditional print copy. In som...</td>\n",
       "      <td>...</td>\n",
       "      <td>False</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>[False, False, False, False, False, False, Fal...</td>\n",
       "      <td>0.213594</td>\n",
       "      <td>42.718895</td>\n",
       "      <td>33.594375</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.213594</td>\n",
       "      <td>0.167972</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>66192</th>\n",
       "      <td>1633</td>\n",
       "      <td>CES attendees inspect Intel UltraBooks at the ...</td>\n",
       "      <td>appease the growing number of employees who a...</td>\n",
       "      <td>1219</td>\n",
       "      <td>1019</td>\n",
       "      <td>200</td>\n",
       "      <td>3.045814</td>\n",
       "      <td>0.448559</td>\n",
       "      <td>[[0.9118322134017944, 0.8717396259307861, 0.69...</td>\n",
       "      <td>keep a laptop in the office and another in th...</td>\n",
       "      <td>...</td>\n",
       "      <td>False</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>[False, False, False, False, False, False, Fal...</td>\n",
       "      <td>0.622416</td>\n",
       "      <td>8.713821</td>\n",
       "      <td>3.290201</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.622416</td>\n",
       "      <td>0.235014</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>66193</th>\n",
       "      <td>1635</td>\n",
       "      <td>Washington, Mar. 9 - Israel is the only safe p...</td>\n",
       "      <td>a wave of church destructions and in Iran, co...</td>\n",
       "      <td>523</td>\n",
       "      <td>323</td>\n",
       "      <td>200</td>\n",
       "      <td>2.861036</td>\n",
       "      <td>2.960533</td>\n",
       "      <td>[[0.693812370300293, 0.6877695322036743, 0.826...</td>\n",
       "      <td>a surge in violence against Christians, espec...</td>\n",
       "      <td>...</td>\n",
       "      <td>False</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>[False, False, False, False, False, False, Fal...</td>\n",
       "      <td>0.243750</td>\n",
       "      <td>48.749969</td>\n",
       "      <td>36.867172</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.243750</td>\n",
       "      <td>0.184336</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>5 rows × 77 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "        idx                                    truncated_input  \\\n",
       "66189  1629  The cast of the 90s TV show, Hip Hip Hurray, j...   \n",
       "66190  1631  Seated left to right are Viktor Averin, Sergei...   \n",
       "66191  1632  Does Age Predict Technology Adoption?\\nA commo...   \n",
       "66192  1633  CES attendees inspect Intel UltraBooks at the ...   \n",
       "66193  1635  Washington, Mar. 9 - Israel is the only safe p...   \n",
       "\n",
       "                                     baseline_completion  orig_sample_length  \\\n",
       "66189  ed the picture post as: Nostalgia#at its best....                 319   \n",
       "66190   \"arguably the mightiest organised crime group...                1130   \n",
       "66191   than bound paper, ink and glue to younger or ...                 886   \n",
       "66192   appease the growing number of employees who a...                1219   \n",
       "66193   a wave of church destructions and in Iran, co...                 523   \n",
       "\n",
       "       prompt_length  real_completion_length  no_bl_gen_time  w_bl_gen_time  \\\n",
       "66189            119                     200        2.813786       0.767504   \n",
       "66190            930                     200        3.019276       1.591323   \n",
       "66191            686                     200        1.283562       3.061106   \n",
       "66192           1019                     200        3.045814       0.448559   \n",
       "66193            323                     200        2.861036       2.960533   \n",
       "\n",
       "                                         spike_entropies  \\\n",
       "66189  [[0.10299381613731384, 0.3138567805290222, 0.2...   \n",
       "66190  [[0.39239728450775146, 0.6695157289505005, 0.3...   \n",
       "66191  [[0.11953060328960419, 0.625767171382904, 0.38...   \n",
       "66192  [[0.9118322134017944, 0.8717396259307861, 0.69...   \n",
       "66193  [[0.693812370300293, 0.6877695322036743, 0.826...   \n",
       "\n",
       "                                            no_bl_output  ...  \\\n",
       "66189  ed the post, \"No cast ever.... (sic).\"\\nHere's...  ...   \n",
       "66190   \"the largest and most powerful mafia organisa...  ...   \n",
       "66191   than that of a traditional print copy. In som...  ...   \n",
       "66192   keep a laptop in the office and another in th...  ...   \n",
       "66193   a surge in violence against Christians, espec...  ...   \n",
       "\n",
       "      w_bl_num_toks_gend_eq_0  w_bl_whitelist_fraction  \\\n",
       "66189                   False                      1.0   \n",
       "66190                   False                      1.0   \n",
       "66191                   False                      1.0   \n",
       "66192                   False                      1.0   \n",
       "66193                   False                      1.0   \n",
       "\n",
       "       w_bl_blacklist_fraction  \\\n",
       "66189                      0.0   \n",
       "66190                      0.0   \n",
       "66191                      0.0   \n",
       "66192                      0.0   \n",
       "66193                      0.0   \n",
       "\n",
       "                                           w_bl_hit_list  avg_spike_entropy  \\\n",
       "66189  [False, False, False, False, False, False, Fal...           0.505296   \n",
       "66190  [False, False, False, False, False, False, Fal...           0.531480   \n",
       "66191  [False, False, False, False, False, False, Fal...           0.213594   \n",
       "66192  [False, False, False, False, False, False, Fal...           0.622416   \n",
       "66193  [False, False, False, False, False, False, Fal...           0.243750   \n",
       "\n",
       "       w_bl_exp_num_wl_tokens  w_bl_var_num_wl_tokens  exp_wl_coef  \\\n",
       "66189               26.275373               12.998542          1.0   \n",
       "66190               49.959114               23.406847          1.0   \n",
       "66191               42.718895               33.594375          1.0   \n",
       "66192                8.713821                3.290201          1.0   \n",
       "66193               48.749969               36.867172          1.0   \n",
       "\n",
       "       w_bl_exp_whitelist_fraction  w_bl_var_whitelist_fraction  \n",
       "66189                     0.505296                     0.249972  \n",
       "66190                     0.531480                     0.249009  \n",
       "66191                     0.213594                     0.167972  \n",
       "66192                     0.622416                     0.235014  \n",
       "66193                     0.243750                     0.184336  \n",
       "\n",
       "[5 rows x 77 columns]"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "print(f\"Orig number of rows: {len(df)}\")\n",
    "df.tail()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Index(['idx', 'truncated_input', 'baseline_completion', 'orig_sample_length',\n",
       "       'prompt_length', 'real_completion_length', 'no_bl_gen_time',\n",
       "       'w_bl_gen_time', 'spike_entropies', 'no_bl_output', 'w_bl_output',\n",
       "       'no_bl_num_tokens_generated', 'w_bl_num_tokens_generated',\n",
       "       'no_bl_sec_per_tok', 'no_bl_tok_per_sec', 'w_bl_sec_per_tok',\n",
       "       'w_bl_tok_per_sec', 'baseline_loss', 'baseline_ppl', 'no_bl_loss',\n",
       "       'no_bl_ppl', 'w_bl_loss', 'w_bl_ppl', 'model_name', 'dataset_name',\n",
       "       'dataset_config_name', 'shuffle_dataset', 'shuffle_seed',\n",
       "       'shuffle_buffer_size', 'max_new_tokens', 'min_prompt_tokens',\n",
       "       'limit_indices', 'input_truncation_strategy',\n",
       "       'input_filtering_strategy', 'output_filtering_strategy', 'initial_seed',\n",
       "       'dynamic_seed', 'bl_proportion', 'bl_logit_bias', 'bl_type',\n",
       "       'num_beams', 'no_repeat_ngram_size', 'early_stopping',\n",
       "       'oracle_model_name', 'no_wandb', 'wandb_project', 'wandb_entity',\n",
       "       'run_name', 'output_dir', 'load_prev_generations', 'store_bl_ids',\n",
       "       'store_spike_ents', 'use_sampling', 'sampling_temp', 'generate_only',\n",
       "       'SLURM_JOB_ID', 'SLURM_ARRAY_JOB_ID', 'SLURM_ARRAY_TASK_ID',\n",
       "       'gen_table_already_existed', 'baseline_num_toks_gend_eq_0',\n",
       "       'baseline_whitelist_fraction', 'baseline_blacklist_fraction',\n",
       "       'baseline_hit_list', 'no_bl_num_toks_gend_eq_0',\n",
       "       'no_bl_whitelist_fraction', 'no_bl_blacklist_fraction',\n",
       "       'no_bl_hit_list', 'w_bl_num_toks_gend_eq_0', 'w_bl_whitelist_fraction',\n",
       "       'w_bl_blacklist_fraction', 'w_bl_hit_list', 'avg_spike_entropy',\n",
       "       'w_bl_exp_num_wl_tokens', 'w_bl_var_num_wl_tokens', 'exp_wl_coef',\n",
       "       'w_bl_exp_whitelist_fraction', 'w_bl_var_whitelist_fraction'],\n",
       "      dtype='object')"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df.columns"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## mega filter block"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Num rows that are hard-blacklisted, and measureable, but still have a non-100% WL fraction: 0 out of 0\n",
      "Dropped 721 rows, new len 65473\n",
      "Dropped 0 rows, new len 65473\n",
      "Dropped 0 rows, new len 65473\n",
      "Dropped 0 rows, new len 65473\n",
      "Dropped 37334 rows, new len 28139\n"
     ]
    }
   ],
   "source": [
    "# drop retok_problematic_rows\n",
    "retok_problematic_rows = df[(df['w_bl_whitelist_fraction'] != -1.0) & (df['w_bl_whitelist_fraction'] != 1.0) & (df['bl_type'] == 'hard')]\n",
    "print(f\"Num rows that are hard-blacklisted, and measureable, but still have a non-100% WL fraction: {len(retok_problematic_rows)} out of {len(df[df['bl_type'] == 'hard'])}\")\n",
    "\n",
    "# drop special rows marked as -1.0\n",
    "orig_len = len(df)\n",
    "\n",
    "# df['no_bl_whitelist_fraction'].mask(df['no_bl_whitelist_fraction'] == -1.0, pd.NA, inplace=True)\n",
    "# df['w_bl_whitelist_fraction'].mask(df['w_bl_whitelist_fraction'] == -1.0, pd.NA, inplace=True)\n",
    "\n",
    "df = df[df[\"no_bl_whitelist_fraction\"] != -1.0]\n",
    "df = df[df[\"w_bl_whitelist_fraction\"] != -1.0]\n",
    "\n",
    "print(f\"Dropped {orig_len-len(df)} rows, new len {len(df)}\")\n",
    "\n",
    "# drop too few tokesn rows\n",
    "\n",
    "orig_len = len(df)\n",
    "# df = df[df[\"no_bl_ppl\"].isna()]\n",
    "# df = df[df[\"w_bl_ppl\"].isna()]\n",
    "df = df[~(df[\"no_bl_ppl\"].isna() | df[\"w_bl_ppl\"].isna())]\n",
    "print(f\"Dropped {orig_len-len(df)} rows, new len {len(df)}\")\n",
    "\n",
    "# drop huge biases\n",
    "orig_len = len(df)\n",
    "\n",
    "df = df[df[\"bl_logit_bias\"] <= 100.0]\n",
    "\n",
    "print(f\"Dropped {orig_len-len(df)} rows, new len {len(df)}\")\n",
    "\n",
    "orig_len = len(df)\n",
    "\n",
    "# df = df[df[\"bl_hparams\"].apply(lambda tup: (tup[0] == False and tup[2] != 1) or (tup[0] == True and tup[2] == 1) or (tup[0] == False))]\n",
    "df = df[((df[\"use_sampling\"]==True) & (df[\"num_beams\"] == 1)) | (df[\"use_sampling\"]==False)]\n",
    "\n",
    "print(f\"Dropped {orig_len-len(df)} rows, new len {len(df)}\")\n",
    "\n",
    "# correct sampling temp\n",
    "df.loc[df[\"use_sampling\"]==False,\"sampling_temp\"] = df.loc[df[\"use_sampling\"]==False,\"sampling_temp\"].fillna(0.0)\n",
    "df.loc[df[\"use_sampling\"]==True,\"sampling_temp\"] = df.loc[df[\"use_sampling\"]==True,\"sampling_temp\"].fillna(1.0)\n",
    "\n",
    "# set to inf for hard blacklist\n",
    "df.loc[df[\"bl_type\"]==\"hard\",\"bl_logit_bias\"] = np.inf\n",
    "# df.loc[df[\"bl_type\"]==\"hard\",\"bl_logit_bias\"] = 10000 # crosscheck with whats hardcoded in the bl processor\n",
    "\n",
    "# rename some stuff\n",
    "df[\"delta\"] = df[\"bl_logit_bias\"].values\n",
    "df[\"gamma\"] = 1 - df[\"bl_proportion\"].values\n",
    "df[\"gamma\"] = df[\"gamma\"].round(3)\n",
    "\n",
    "df[\"no_bl_act_num_wl_tokens\"] = np.round(df[\"no_bl_whitelist_fraction\"].values*df[\"no_bl_num_tokens_generated\"],1) # round to 1 for sanity\n",
    "df[\"w_bl_act_num_wl_tokens\"] = np.round(df[\"w_bl_whitelist_fraction\"].values*df[\"w_bl_num_tokens_generated\"],1) # round to 1 for sanity\n",
    "\n",
    "df[\"w_bl_std_num_wl_tokens\"] = np.sqrt(df[\"w_bl_var_num_wl_tokens\"].values)\n",
    "\n",
    "if \"real_completion_length\":\n",
    "    df[\"baseline_num_tokens_generated\"] = df[\"real_completion_length\"].values\n",
    "\n",
    "if \"actual_attacked_ratio\" in df.columns:\n",
    "    df[\"actual_attacked_fraction\"] = df[\"actual_attacked_ratio\"].values*df[\"replace_ratio\"].values\n",
    "\n",
    "if \"meta\" in df.columns:\n",
    "    df[\"pile_set_name\"] = df[\"meta\"].apply(lambda dict: dict[\"pile_set_name\"])\n",
    "\n",
    "df[\"baseline_hit_list_length\"] = df[\"baseline_hit_list\"].apply(len)\n",
    "df[\"no_bl_hit_list_length\"] = df[\"no_bl_hit_list\"].apply(len)\n",
    "df[\"w_bl_hit_list_length\"] = df[\"w_bl_hit_list\"].apply(len)\n",
    "\n",
    "\n",
    "# for pile outlier filtering\n",
    "df[\"w_bl_space_count\"] = df[\"w_bl_output\"].apply(lambda string: string.count(\" \"))\n",
    "df[\"no_bl_space_count\"] = df[\"no_bl_output\"].apply(lambda string: string.count(\" \"))\n",
    "df[\"baseline_space_count\"] = df[\"baseline_completion\"].apply(lambda string: string.count(\" \"))\n",
    "\n",
    "df[\"w_bl_space_frac\"] = df[\"w_bl_space_count\"].values / df[\"w_bl_hit_list_length\"]\n",
    "df[\"no_bl_space_frac\"] = df[\"no_bl_space_count\"].values / df[\"no_bl_hit_list_length\"]\n",
    "df[\"baseline_space_frac\"] = df[\"baseline_space_count\"].values / df[\"baseline_hit_list_length\"]\n",
    "\n",
    "\n",
    "# Final length filtering \n",
    "\n",
    "orig_len = len(df)\n",
    "\n",
    "# # main filters\n",
    "# # df = df[(df[\"real_completion_length\"] == 200) & (df[\"w_bl_num_tokens_generated\"] == 200)]\n",
    "# df = df[(df[\"gamma\"] == 0.1) | (df[\"gamma\"] == 0.25) | (df[\"gamma\"] == 0.5)]\n",
    "# df = df[(df[\"delta\"] == 1.0) | (df[\"delta\"] == 2.0) | (df[\"delta\"] == 10.0)]\n",
    "# df = df[(df[\"use_sampling\"] == True)]\n",
    "# df = df[(df[\"bl_type\"] == \"soft\")]\n",
    "\n",
    "# df = df[(df[\"real_completion_length\"] == 200) & (df[\"no_bl_num_tokens_generated\"] == 200) & (df[\"w_bl_num_tokens_generated\"] == 200)] # now also applies to the truncated version\n",
    "# df = df[(df[\"no_bl_num_tokens_generated\"] >= 500) & (df[\"w_bl_num_tokens_generated\"] >= 500)] # all gas noop\n",
    "\n",
    "# # # attack specific\n",
    "# df = df[(df[\"real_completion_length\"] == 200) & (df[\"no_bl_num_tokens_generated\"] == 200) & (df[\"w_bl_num_tokens_generated\"] == 200)]\n",
    "# df = df[(df[\"replace_ratio\"] <= 0.7)]\n",
    "\n",
    "# # NOTE pile only\n",
    "# df = df[df[\"w_bl_space_frac\"] <= 0.9]\n",
    "# df = df[df[\"no_bl_space_frac\"] <= 0.9]\n",
    "# df = df[df[\"pile_set_name\"] != \"Github\"]\n",
    "\n",
    "upper_T = 205\n",
    "lower_T = 195\n",
    "df = df[(df[\"baseline_hit_list_length\"] >= lower_T) & (df[\"no_bl_hit_list_length\"] >= lower_T) & (df[\"w_bl_hit_list_length\"] >= lower_T)] # now also applies to the truncated version\n",
    "df = df[(df[\"baseline_hit_list_length\"] <= upper_T) & (df[\"no_bl_hit_list_length\"] <= upper_T) & (df[\"w_bl_hit_list_length\"] <= upper_T)] # now also applies to the truncated version\n",
    "\n",
    "\n",
    "print(f\"Dropped {orig_len-len(df)} rows, new len {len(df)}\")"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Add z-scores"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "from math import sqrt\n",
    "import scipy.stats\n",
    "def compute_z_score(observed_wl_frac, T, gamma):\n",
    "    numer = observed_wl_frac - gamma\n",
    "    denom = sqrt(gamma*(1-gamma)/T)\n",
    "    z = numer/denom\n",
    "    return z\n",
    "\n",
    "def compute_wl_for_z(z, T, gamma):\n",
    "    denom = sqrt(gamma*(1-gamma)/T)\n",
    "    numer = ((z*denom)+gamma)*T\n",
    "    return numer\n",
    "\n",
    "def compute_p_value(z):\n",
    "    p_value = scipy.stats.norm.sf(z)\n",
    "    return p_value\n",
    "\n",
    "df[\"baseline_z_score\"] = df[[\"baseline_whitelist_fraction\", \"baseline_num_tokens_generated\", \"gamma\"]].apply(lambda tup: compute_z_score(*tup), axis=1)\n",
    "df[\"no_bl_z_score\"] = df[[\"no_bl_whitelist_fraction\", \"no_bl_num_tokens_generated\", \"gamma\"]].apply(lambda tup: compute_z_score(*tup), axis=1)\n",
    "df[\"w_bl_z_score\"] = df[[\"w_bl_whitelist_fraction\", \"w_bl_num_tokens_generated\", \"gamma\"]].apply(lambda tup: compute_z_score(*tup), axis=1)\n",
    "\n",
    "if \"w_bl_attacked_whitelist_fraction\" in df.columns:\n",
    "    df[\"w_bl_attacked_z_score\"] = df[[\"w_bl_attacked_whitelist_fraction\", \"w_bl_attacked_num_tokens_generated\", \"gamma\"]].apply(lambda tup: compute_z_score(*tup), axis=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "# if attacked in df\n",
    "if \"w_bl_attacked_whitelist_fraction\" in df.columns:\n",
    "    df[\"w_bl_attacked_act_num_wl_tokens\"] = np.round(df[\"w_bl_attacked_whitelist_fraction\"].values*df[\"w_bl_attacked_num_tokens_generated\"],1) # round to 1 for sanity\n",
    "\n",
    "    df[\"w_bl_attacked_z_score\"] = df[[\"w_bl_attacked_whitelist_fraction\", \"w_bl_attacked_num_tokens_generated\", \"gamma\"]].apply(lambda tup: compute_z_score(*tup), axis=1)\n",
    "\n",
    "    df[[\"bl_proportion\",\"w_bl_attacked_whitelist_fraction\", \"w_bl_attacked_num_tokens_generated\",\"w_bl_attacked_act_num_wl_tokens\", \"w_bl_attacked_z_score\"]]"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Groupby (decide which hyperparameters to groups the rows by)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "if \"w_bl_attacked_whitelist_fraction\" in df.columns: \n",
    "    groupby_fields = ['use_sampling','num_beams','gamma','delta', 'replace_ratio'] # attack grouping\n",
    "else:\n",
    "    groupby_fields = ['use_sampling','num_beams','delta','gamma'] # regular grouping"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "grouped_df = df.groupby(groupby_fields)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of rows after filtering: 28139\n",
      "Number of groups: 56\n"
     ]
    }
   ],
   "source": [
    "print(f\"Number of rows after filtering: {len(df)}\")\n",
    "print(f\"Number of groups: {len(grouped_df)}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>count</th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "      <th>min</th>\n",
       "      <th>25%</th>\n",
       "      <th>50%</th>\n",
       "      <th>75%</th>\n",
       "      <th>max</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>use_sampling</th>\n",
       "      <th>num_beams</th>\n",
       "      <th>delta</th>\n",
       "      <th>gamma</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"21\" valign=\"top\">False</th>\n",
       "      <th rowspan=\"7\" valign=\"top\">1</th>\n",
       "      <th>0.1</th>\n",
       "      <th>0.50</th>\n",
       "      <td>497.0</td>\n",
       "      <td>0.775204</td>\n",
       "      <td>2.517472</td>\n",
       "      <td>-6.788225</td>\n",
       "      <td>-0.707107</td>\n",
       "      <td>0.707107</td>\n",
       "      <td>2.262742</td>\n",
       "      <td>13.859293</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.5</th>\n",
       "      <th>0.50</th>\n",
       "      <td>496.0</td>\n",
       "      <td>2.905542</td>\n",
       "      <td>2.515852</td>\n",
       "      <td>-5.798276</td>\n",
       "      <td>1.320812</td>\n",
       "      <td>2.969848</td>\n",
       "      <td>4.384062</td>\n",
       "      <td>13.859293</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1.0</th>\n",
       "      <th>0.50</th>\n",
       "      <td>497.0</td>\n",
       "      <td>5.407189</td>\n",
       "      <td>2.606488</td>\n",
       "      <td>-3.394113</td>\n",
       "      <td>3.676955</td>\n",
       "      <td>5.515433</td>\n",
       "      <td>7.071068</td>\n",
       "      <td>14.142136</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2.0</th>\n",
       "      <th>0.50</th>\n",
       "      <td>495.0</td>\n",
       "      <td>8.785251</td>\n",
       "      <td>2.422845</td>\n",
       "      <td>-1.555635</td>\n",
       "      <td>7.636753</td>\n",
       "      <td>8.909545</td>\n",
       "      <td>10.182338</td>\n",
       "      <td>14.142136</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5.0</th>\n",
       "      <th>0.50</th>\n",
       "      <td>495.0</td>\n",
       "      <td>12.431525</td>\n",
       "      <td>1.582604</td>\n",
       "      <td>0.848528</td>\n",
       "      <td>11.879394</td>\n",
       "      <td>12.727922</td>\n",
       "      <td>13.435029</td>\n",
       "      <td>14.142136</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10.0</th>\n",
       "      <th>0.50</th>\n",
       "      <td>491.0</td>\n",
       "      <td>13.988974</td>\n",
       "      <td>0.397100</td>\n",
       "      <td>10.748023</td>\n",
       "      <td>14.000714</td>\n",
       "      <td>14.142136</td>\n",
       "      <td>14.142136</td>\n",
       "      <td>14.142136</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>50.0</th>\n",
       "      <th>0.50</th>\n",
       "      <td>488.0</td>\n",
       "      <td>14.076854</td>\n",
       "      <td>0.333189</td>\n",
       "      <td>10.748023</td>\n",
       "      <td>14.142136</td>\n",
       "      <td>14.142136</td>\n",
       "      <td>14.142136</td>\n",
       "      <td>14.142136</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"7\" valign=\"top\">4</th>\n",
       "      <th>0.1</th>\n",
       "      <th>0.50</th>\n",
       "      <td>500.0</td>\n",
       "      <td>1.225231</td>\n",
       "      <td>1.931048</td>\n",
       "      <td>-5.091169</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>1.272792</td>\n",
       "      <td>2.545584</td>\n",
       "      <td>8.202439</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.5</th>\n",
       "      <th>0.50</th>\n",
       "      <td>504.0</td>\n",
       "      <td>4.121540</td>\n",
       "      <td>1.785928</td>\n",
       "      <td>-2.545584</td>\n",
       "      <td>2.969848</td>\n",
       "      <td>4.101219</td>\n",
       "      <td>5.232590</td>\n",
       "      <td>9.616652</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1.0</th>\n",
       "      <th>0.50</th>\n",
       "      <td>506.0</td>\n",
       "      <td>7.248399</td>\n",
       "      <td>1.827018</td>\n",
       "      <td>1.838478</td>\n",
       "      <td>6.146552</td>\n",
       "      <td>7.212489</td>\n",
       "      <td>8.485281</td>\n",
       "      <td>12.586501</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2.0</th>\n",
       "      <th>0.50</th>\n",
       "      <td>504.0</td>\n",
       "      <td>11.145401</td>\n",
       "      <td>1.429662</td>\n",
       "      <td>3.252691</td>\n",
       "      <td>10.465180</td>\n",
       "      <td>11.455130</td>\n",
       "      <td>12.020815</td>\n",
       "      <td>13.859293</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5.0</th>\n",
       "      <th>0.50</th>\n",
       "      <td>507.0</td>\n",
       "      <td>13.921719</td>\n",
       "      <td>0.441143</td>\n",
       "      <td>8.909545</td>\n",
       "      <td>13.859293</td>\n",
       "      <td>14.000714</td>\n",
       "      <td>14.142136</td>\n",
       "      <td>14.142136</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10.0</th>\n",
       "      <th>0.50</th>\n",
       "      <td>505.0</td>\n",
       "      <td>14.112293</td>\n",
       "      <td>0.129659</td>\n",
       "      <td>12.586501</td>\n",
       "      <td>14.142136</td>\n",
       "      <td>14.142136</td>\n",
       "      <td>14.142136</td>\n",
       "      <td>14.142136</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>50.0</th>\n",
       "      <th>0.50</th>\n",
       "      <td>508.0</td>\n",
       "      <td>14.117756</td>\n",
       "      <td>0.123950</td>\n",
       "      <td>12.586501</td>\n",
       "      <td>14.142136</td>\n",
       "      <td>14.142136</td>\n",
       "      <td>14.142136</td>\n",
       "      <td>14.142136</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"7\" valign=\"top\">8</th>\n",
       "      <th>0.1</th>\n",
       "      <th>0.50</th>\n",
       "      <td>501.0</td>\n",
       "      <td>1.194271</td>\n",
       "      <td>1.867354</td>\n",
       "      <td>-5.232590</td>\n",
       "      <td>0.141421</td>\n",
       "      <td>1.272792</td>\n",
       "      <td>2.404163</td>\n",
       "      <td>6.646804</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.5</th>\n",
       "      <th>0.50</th>\n",
       "      <td>503.0</td>\n",
       "      <td>4.403488</td>\n",
       "      <td>1.913617</td>\n",
       "      <td>-2.687006</td>\n",
       "      <td>3.252691</td>\n",
       "      <td>4.477159</td>\n",
       "      <td>5.656854</td>\n",
       "      <td>10.889444</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1.0</th>\n",
       "      <th>0.50</th>\n",
       "      <td>501.0</td>\n",
       "      <td>7.862284</td>\n",
       "      <td>1.909225</td>\n",
       "      <td>1.414214</td>\n",
       "      <td>6.788225</td>\n",
       "      <td>7.919596</td>\n",
       "      <td>9.192388</td>\n",
       "      <td>12.586501</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2.0</th>\n",
       "      <th>0.50</th>\n",
       "      <td>502.0</td>\n",
       "      <td>11.743655</td>\n",
       "      <td>1.245523</td>\n",
       "      <td>3.959798</td>\n",
       "      <td>11.172287</td>\n",
       "      <td>11.879394</td>\n",
       "      <td>12.586501</td>\n",
       "      <td>14.000714</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5.0</th>\n",
       "      <th>0.50</th>\n",
       "      <td>498.0</td>\n",
       "      <td>14.048135</td>\n",
       "      <td>0.184397</td>\n",
       "      <td>12.162237</td>\n",
       "      <td>14.000714</td>\n",
       "      <td>14.142136</td>\n",
       "      <td>14.142136</td>\n",
       "      <td>14.142136</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10.0</th>\n",
       "      <th>0.50</th>\n",
       "      <td>500.0</td>\n",
       "      <td>14.118455</td>\n",
       "      <td>0.145913</td>\n",
       "      <td>11.879394</td>\n",
       "      <td>14.142136</td>\n",
       "      <td>14.142136</td>\n",
       "      <td>14.142136</td>\n",
       "      <td>14.142136</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>50.0</th>\n",
       "      <th>0.50</th>\n",
       "      <td>502.0</td>\n",
       "      <td>14.120095</td>\n",
       "      <td>0.144250</td>\n",
       "      <td>11.879394</td>\n",
       "      <td>14.142136</td>\n",
       "      <td>14.142136</td>\n",
       "      <td>14.142136</td>\n",
       "      <td>14.142136</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"35\" valign=\"top\">True</th>\n",
       "      <th rowspan=\"35\" valign=\"top\">1</th>\n",
       "      <th rowspan=\"5\" valign=\"top\">0.1</th>\n",
       "      <th>0.10</th>\n",
       "      <td>507.0</td>\n",
       "      <td>0.794085</td>\n",
       "      <td>1.477187</td>\n",
       "      <td>-4.477159</td>\n",
       "      <td>-0.235702</td>\n",
       "      <td>0.707107</td>\n",
       "      <td>1.649916</td>\n",
       "      <td>5.605258</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.25</th>\n",
       "      <td>510.0</td>\n",
       "      <td>0.174547</td>\n",
       "      <td>1.231675</td>\n",
       "      <td>-3.265986</td>\n",
       "      <td>-0.653197</td>\n",
       "      <td>0.163299</td>\n",
       "      <td>0.979796</td>\n",
       "      <td>8.491564</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.50</th>\n",
       "      <td>504.0</td>\n",
       "      <td>0.785959</td>\n",
       "      <td>1.331575</td>\n",
       "      <td>-3.676955</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.848528</td>\n",
       "      <td>1.555635</td>\n",
       "      <td>10.465180</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.75</th>\n",
       "      <td>506.0</td>\n",
       "      <td>0.769141</td>\n",
       "      <td>1.216546</td>\n",
       "      <td>-6.858571</td>\n",
       "      <td>0.163299</td>\n",
       "      <td>0.816497</td>\n",
       "      <td>1.632993</td>\n",
       "      <td>4.409082</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.90</th>\n",
       "      <td>505.0</td>\n",
       "      <td>0.426764</td>\n",
       "      <td>1.078141</td>\n",
       "      <td>-3.064129</td>\n",
       "      <td>-0.235702</td>\n",
       "      <td>0.471405</td>\n",
       "      <td>1.178511</td>\n",
       "      <td>3.771236</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"5\" valign=\"top\">0.5</th>\n",
       "      <th>0.10</th>\n",
       "      <td>502.0</td>\n",
       "      <td>2.190078</td>\n",
       "      <td>1.583207</td>\n",
       "      <td>-2.357023</td>\n",
       "      <td>1.178511</td>\n",
       "      <td>2.121320</td>\n",
       "      <td>3.299832</td>\n",
       "      <td>7.071068</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.25</th>\n",
       "      <td>503.0</td>\n",
       "      <td>2.067980</td>\n",
       "      <td>1.321680</td>\n",
       "      <td>-1.796292</td>\n",
       "      <td>1.143095</td>\n",
       "      <td>2.122891</td>\n",
       "      <td>2.939388</td>\n",
       "      <td>7.185170</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.50</th>\n",
       "      <td>503.0</td>\n",
       "      <td>2.769410</td>\n",
       "      <td>1.401529</td>\n",
       "      <td>-12.020815</td>\n",
       "      <td>2.121320</td>\n",
       "      <td>2.828427</td>\n",
       "      <td>3.535534</td>\n",
       "      <td>6.788225</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.75</th>\n",
       "      <td>504.0</td>\n",
       "      <td>2.258562</td>\n",
       "      <td>1.120684</td>\n",
       "      <td>-3.265986</td>\n",
       "      <td>1.469694</td>\n",
       "      <td>2.286190</td>\n",
       "      <td>3.102687</td>\n",
       "      <td>5.552177</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.90</th>\n",
       "      <td>515.0</td>\n",
       "      <td>1.352280</td>\n",
       "      <td>1.087089</td>\n",
       "      <td>-4.949747</td>\n",
       "      <td>0.707107</td>\n",
       "      <td>1.414214</td>\n",
       "      <td>2.121320</td>\n",
       "      <td>3.535534</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"5\" valign=\"top\">1.0</th>\n",
       "      <th>0.10</th>\n",
       "      <td>506.0</td>\n",
       "      <td>4.505423</td>\n",
       "      <td>1.912686</td>\n",
       "      <td>-3.535534</td>\n",
       "      <td>3.299832</td>\n",
       "      <td>4.478343</td>\n",
       "      <td>5.656854</td>\n",
       "      <td>11.394250</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.25</th>\n",
       "      <td>506.0</td>\n",
       "      <td>4.788918</td>\n",
       "      <td>1.523620</td>\n",
       "      <td>-0.653197</td>\n",
       "      <td>3.919184</td>\n",
       "      <td>4.898979</td>\n",
       "      <td>5.715476</td>\n",
       "      <td>8.981462</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.50</th>\n",
       "      <td>506.0</td>\n",
       "      <td>4.899046</td>\n",
       "      <td>1.496086</td>\n",
       "      <td>-1.272792</td>\n",
       "      <td>4.101219</td>\n",
       "      <td>5.091169</td>\n",
       "      <td>5.939697</td>\n",
       "      <td>11.313708</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.75</th>\n",
       "      <td>504.0</td>\n",
       "      <td>3.794776</td>\n",
       "      <td>1.005397</td>\n",
       "      <td>-0.326599</td>\n",
       "      <td>3.265986</td>\n",
       "      <td>3.919184</td>\n",
       "      <td>4.427768</td>\n",
       "      <td>6.042075</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.90</th>\n",
       "      <td>501.0</td>\n",
       "      <td>2.187248</td>\n",
       "      <td>0.995490</td>\n",
       "      <td>-3.771236</td>\n",
       "      <td>1.649916</td>\n",
       "      <td>2.357023</td>\n",
       "      <td>2.828427</td>\n",
       "      <td>4.714045</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"5\" valign=\"top\">2.0</th>\n",
       "      <th>0.10</th>\n",
       "      <td>507.0</td>\n",
       "      <td>11.266219</td>\n",
       "      <td>2.745536</td>\n",
       "      <td>1.649916</td>\n",
       "      <td>9.663793</td>\n",
       "      <td>11.078006</td>\n",
       "      <td>12.963624</td>\n",
       "      <td>26.870058</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.25</th>\n",
       "      <td>505.0</td>\n",
       "      <td>10.669313</td>\n",
       "      <td>2.263002</td>\n",
       "      <td>-1.143095</td>\n",
       "      <td>9.308061</td>\n",
       "      <td>10.614456</td>\n",
       "      <td>11.920850</td>\n",
       "      <td>24.331598</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.50</th>\n",
       "      <td>507.0</td>\n",
       "      <td>8.520831</td>\n",
       "      <td>1.498280</td>\n",
       "      <td>-1.131371</td>\n",
       "      <td>7.919596</td>\n",
       "      <td>8.768124</td>\n",
       "      <td>9.333810</td>\n",
       "      <td>12.727922</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.75</th>\n",
       "      <td>505.0</td>\n",
       "      <td>5.494584</td>\n",
       "      <td>1.076413</td>\n",
       "      <td>-1.469694</td>\n",
       "      <td>5.062279</td>\n",
       "      <td>5.552177</td>\n",
       "      <td>6.205374</td>\n",
       "      <td>8.164966</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.90</th>\n",
       "      <td>505.0</td>\n",
       "      <td>3.283954</td>\n",
       "      <td>0.826203</td>\n",
       "      <td>-2.357023</td>\n",
       "      <td>2.828427</td>\n",
       "      <td>3.299832</td>\n",
       "      <td>3.771236</td>\n",
       "      <td>4.714045</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"5\" valign=\"top\">5.0</th>\n",
       "      <th>0.10</th>\n",
       "      <td>501.0</td>\n",
       "      <td>33.031715</td>\n",
       "      <td>4.074784</td>\n",
       "      <td>20.270394</td>\n",
       "      <td>30.405592</td>\n",
       "      <td>32.762614</td>\n",
       "      <td>35.119637</td>\n",
       "      <td>42.426407</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.25</th>\n",
       "      <td>503.0</td>\n",
       "      <td>21.247814</td>\n",
       "      <td>1.998682</td>\n",
       "      <td>4.536092</td>\n",
       "      <td>20.085816</td>\n",
       "      <td>21.392210</td>\n",
       "      <td>22.535306</td>\n",
       "      <td>24.494897</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.50</th>\n",
       "      <td>504.0</td>\n",
       "      <td>12.566653</td>\n",
       "      <td>1.241437</td>\n",
       "      <td>2.828427</td>\n",
       "      <td>12.162237</td>\n",
       "      <td>12.866145</td>\n",
       "      <td>13.293607</td>\n",
       "      <td>14.142136</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.75</th>\n",
       "      <td>502.0</td>\n",
       "      <td>7.432600</td>\n",
       "      <td>0.752119</td>\n",
       "      <td>0.163299</td>\n",
       "      <td>7.185170</td>\n",
       "      <td>7.513393</td>\n",
       "      <td>7.838367</td>\n",
       "      <td>8.164966</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.90</th>\n",
       "      <td>501.0</td>\n",
       "      <td>4.275912</td>\n",
       "      <td>0.514057</td>\n",
       "      <td>-0.235702</td>\n",
       "      <td>4.006938</td>\n",
       "      <td>4.478343</td>\n",
       "      <td>4.714045</td>\n",
       "      <td>4.714045</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"5\" valign=\"top\">10.0</th>\n",
       "      <th>0.10</th>\n",
       "      <td>490.0</td>\n",
       "      <td>41.556418</td>\n",
       "      <td>1.800056</td>\n",
       "      <td>19.327585</td>\n",
       "      <td>41.480045</td>\n",
       "      <td>41.956175</td>\n",
       "      <td>42.426407</td>\n",
       "      <td>42.426407</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.25</th>\n",
       "      <td>499.0</td>\n",
       "      <td>24.166544</td>\n",
       "      <td>0.884251</td>\n",
       "      <td>7.838367</td>\n",
       "      <td>24.007437</td>\n",
       "      <td>24.331598</td>\n",
       "      <td>24.494897</td>\n",
       "      <td>24.494897</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.50</th>\n",
       "      <td>507.0</td>\n",
       "      <td>13.973804</td>\n",
       "      <td>0.251381</td>\n",
       "      <td>12.162237</td>\n",
       "      <td>13.859293</td>\n",
       "      <td>14.071247</td>\n",
       "      <td>14.142136</td>\n",
       "      <td>14.142136</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.75</th>\n",
       "      <td>504.0</td>\n",
       "      <td>8.079043</td>\n",
       "      <td>0.183141</td>\n",
       "      <td>6.531973</td>\n",
       "      <td>8.001666</td>\n",
       "      <td>8.164966</td>\n",
       "      <td>8.164966</td>\n",
       "      <td>8.164966</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.90</th>\n",
       "      <td>504.0</td>\n",
       "      <td>4.641317</td>\n",
       "      <td>0.165916</td>\n",
       "      <td>3.535534</td>\n",
       "      <td>4.714045</td>\n",
       "      <td>4.714045</td>\n",
       "      <td>4.714045</td>\n",
       "      <td>4.714045</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"5\" valign=\"top\">50.0</th>\n",
       "      <th>0.10</th>\n",
       "      <td>492.0</td>\n",
       "      <td>41.949981</td>\n",
       "      <td>2.079875</td>\n",
       "      <td>11.549411</td>\n",
       "      <td>42.426407</td>\n",
       "      <td>42.426407</td>\n",
       "      <td>42.426407</td>\n",
       "      <td>42.426407</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.25</th>\n",
       "      <td>501.0</td>\n",
       "      <td>24.342487</td>\n",
       "      <td>0.520410</td>\n",
       "      <td>18.094221</td>\n",
       "      <td>24.494897</td>\n",
       "      <td>24.494897</td>\n",
       "      <td>24.494897</td>\n",
       "      <td>24.494897</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.50</th>\n",
       "      <td>505.0</td>\n",
       "      <td>14.069388</td>\n",
       "      <td>0.188683</td>\n",
       "      <td>12.162237</td>\n",
       "      <td>14.142136</td>\n",
       "      <td>14.142136</td>\n",
       "      <td>14.142136</td>\n",
       "      <td>14.142136</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.75</th>\n",
       "      <td>506.0</td>\n",
       "      <td>8.137593</td>\n",
       "      <td>0.113673</td>\n",
       "      <td>7.033188</td>\n",
       "      <td>8.164966</td>\n",
       "      <td>8.164966</td>\n",
       "      <td>8.164966</td>\n",
       "      <td>8.164966</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.90</th>\n",
       "      <td>509.0</td>\n",
       "      <td>4.709180</td>\n",
       "      <td>0.035999</td>\n",
       "      <td>4.244986</td>\n",
       "      <td>4.714045</td>\n",
       "      <td>4.714045</td>\n",
       "      <td>4.714045</td>\n",
       "      <td>4.714045</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                    count       mean       std        min  \\\n",
       "use_sampling num_beams delta gamma                                          \n",
       "False        1         0.1   0.50   497.0   0.775204  2.517472  -6.788225   \n",
       "                       0.5   0.50   496.0   2.905542  2.515852  -5.798276   \n",
       "                       1.0   0.50   497.0   5.407189  2.606488  -3.394113   \n",
       "                       2.0   0.50   495.0   8.785251  2.422845  -1.555635   \n",
       "                       5.0   0.50   495.0  12.431525  1.582604   0.848528   \n",
       "                       10.0  0.50   491.0  13.988974  0.397100  10.748023   \n",
       "                       50.0  0.50   488.0  14.076854  0.333189  10.748023   \n",
       "             4         0.1   0.50   500.0   1.225231  1.931048  -5.091169   \n",
       "                       0.5   0.50   504.0   4.121540  1.785928  -2.545584   \n",
       "                       1.0   0.50   506.0   7.248399  1.827018   1.838478   \n",
       "                       2.0   0.50   504.0  11.145401  1.429662   3.252691   \n",
       "                       5.0   0.50   507.0  13.921719  0.441143   8.909545   \n",
       "                       10.0  0.50   505.0  14.112293  0.129659  12.586501   \n",
       "                       50.0  0.50   508.0  14.117756  0.123950  12.586501   \n",
       "             8         0.1   0.50   501.0   1.194271  1.867354  -5.232590   \n",
       "                       0.5   0.50   503.0   4.403488  1.913617  -2.687006   \n",
       "                       1.0   0.50   501.0   7.862284  1.909225   1.414214   \n",
       "                       2.0   0.50   502.0  11.743655  1.245523   3.959798   \n",
       "                       5.0   0.50   498.0  14.048135  0.184397  12.162237   \n",
       "                       10.0  0.50   500.0  14.118455  0.145913  11.879394   \n",
       "                       50.0  0.50   502.0  14.120095  0.144250  11.879394   \n",
       "True         1         0.1   0.10   507.0   0.794085  1.477187  -4.477159   \n",
       "                             0.25   510.0   0.174547  1.231675  -3.265986   \n",
       "                             0.50   504.0   0.785959  1.331575  -3.676955   \n",
       "                             0.75   506.0   0.769141  1.216546  -6.858571   \n",
       "                             0.90   505.0   0.426764  1.078141  -3.064129   \n",
       "                       0.5   0.10   502.0   2.190078  1.583207  -2.357023   \n",
       "                             0.25   503.0   2.067980  1.321680  -1.796292   \n",
       "                             0.50   503.0   2.769410  1.401529 -12.020815   \n",
       "                             0.75   504.0   2.258562  1.120684  -3.265986   \n",
       "                             0.90   515.0   1.352280  1.087089  -4.949747   \n",
       "                       1.0   0.10   506.0   4.505423  1.912686  -3.535534   \n",
       "                             0.25   506.0   4.788918  1.523620  -0.653197   \n",
       "                             0.50   506.0   4.899046  1.496086  -1.272792   \n",
       "                             0.75   504.0   3.794776  1.005397  -0.326599   \n",
       "                             0.90   501.0   2.187248  0.995490  -3.771236   \n",
       "                       2.0   0.10   507.0  11.266219  2.745536   1.649916   \n",
       "                             0.25   505.0  10.669313  2.263002  -1.143095   \n",
       "                             0.50   507.0   8.520831  1.498280  -1.131371   \n",
       "                             0.75   505.0   5.494584  1.076413  -1.469694   \n",
       "                             0.90   505.0   3.283954  0.826203  -2.357023   \n",
       "                       5.0   0.10   501.0  33.031715  4.074784  20.270394   \n",
       "                             0.25   503.0  21.247814  1.998682   4.536092   \n",
       "                             0.50   504.0  12.566653  1.241437   2.828427   \n",
       "                             0.75   502.0   7.432600  0.752119   0.163299   \n",
       "                             0.90   501.0   4.275912  0.514057  -0.235702   \n",
       "                       10.0  0.10   490.0  41.556418  1.800056  19.327585   \n",
       "                             0.25   499.0  24.166544  0.884251   7.838367   \n",
       "                             0.50   507.0  13.973804  0.251381  12.162237   \n",
       "                             0.75   504.0   8.079043  0.183141   6.531973   \n",
       "                             0.90   504.0   4.641317  0.165916   3.535534   \n",
       "                       50.0  0.10   492.0  41.949981  2.079875  11.549411   \n",
       "                             0.25   501.0  24.342487  0.520410  18.094221   \n",
       "                             0.50   505.0  14.069388  0.188683  12.162237   \n",
       "                             0.75   506.0   8.137593  0.113673   7.033188   \n",
       "                             0.90   509.0   4.709180  0.035999   4.244986   \n",
       "\n",
       "                                          25%        50%        75%        max  \n",
       "use_sampling num_beams delta gamma                                              \n",
       "False        1         0.1   0.50   -0.707107   0.707107   2.262742  13.859293  \n",
       "                       0.5   0.50    1.320812   2.969848   4.384062  13.859293  \n",
       "                       1.0   0.50    3.676955   5.515433   7.071068  14.142136  \n",
       "                       2.0   0.50    7.636753   8.909545  10.182338  14.142136  \n",
       "                       5.0   0.50   11.879394  12.727922  13.435029  14.142136  \n",
       "                       10.0  0.50   14.000714  14.142136  14.142136  14.142136  \n",
       "                       50.0  0.50   14.142136  14.142136  14.142136  14.142136  \n",
       "             4         0.1   0.50    0.000000   1.272792   2.545584   8.202439  \n",
       "                       0.5   0.50    2.969848   4.101219   5.232590   9.616652  \n",
       "                       1.0   0.50    6.146552   7.212489   8.485281  12.586501  \n",
       "                       2.0   0.50   10.465180  11.455130  12.020815  13.859293  \n",
       "                       5.0   0.50   13.859293  14.000714  14.142136  14.142136  \n",
       "                       10.0  0.50   14.142136  14.142136  14.142136  14.142136  \n",
       "                       50.0  0.50   14.142136  14.142136  14.142136  14.142136  \n",
       "             8         0.1   0.50    0.141421   1.272792   2.404163   6.646804  \n",
       "                       0.5   0.50    3.252691   4.477159   5.656854  10.889444  \n",
       "                       1.0   0.50    6.788225   7.919596   9.192388  12.586501  \n",
       "                       2.0   0.50   11.172287  11.879394  12.586501  14.000714  \n",
       "                       5.0   0.50   14.000714  14.142136  14.142136  14.142136  \n",
       "                       10.0  0.50   14.142136  14.142136  14.142136  14.142136  \n",
       "                       50.0  0.50   14.142136  14.142136  14.142136  14.142136  \n",
       "True         1         0.1   0.10   -0.235702   0.707107   1.649916   5.605258  \n",
       "                             0.25   -0.653197   0.163299   0.979796   8.491564  \n",
       "                             0.50    0.000000   0.848528   1.555635  10.465180  \n",
       "                             0.75    0.163299   0.816497   1.632993   4.409082  \n",
       "                             0.90   -0.235702   0.471405   1.178511   3.771236  \n",
       "                       0.5   0.10    1.178511   2.121320   3.299832   7.071068  \n",
       "                             0.25    1.143095   2.122891   2.939388   7.185170  \n",
       "                             0.50    2.121320   2.828427   3.535534   6.788225  \n",
       "                             0.75    1.469694   2.286190   3.102687   5.552177  \n",
       "                             0.90    0.707107   1.414214   2.121320   3.535534  \n",
       "                       1.0   0.10    3.299832   4.478343   5.656854  11.394250  \n",
       "                             0.25    3.919184   4.898979   5.715476   8.981462  \n",
       "                             0.50    4.101219   5.091169   5.939697  11.313708  \n",
       "                             0.75    3.265986   3.919184   4.427768   6.042075  \n",
       "                             0.90    1.649916   2.357023   2.828427   4.714045  \n",
       "                       2.0   0.10    9.663793  11.078006  12.963624  26.870058  \n",
       "                             0.25    9.308061  10.614456  11.920850  24.331598  \n",
       "                             0.50    7.919596   8.768124   9.333810  12.727922  \n",
       "                             0.75    5.062279   5.552177   6.205374   8.164966  \n",
       "                             0.90    2.828427   3.299832   3.771236   4.714045  \n",
       "                       5.0   0.10   30.405592  32.762614  35.119637  42.426407  \n",
       "                             0.25   20.085816  21.392210  22.535306  24.494897  \n",
       "                             0.50   12.162237  12.866145  13.293607  14.142136  \n",
       "                             0.75    7.185170   7.513393   7.838367   8.164966  \n",
       "                             0.90    4.006938   4.478343   4.714045   4.714045  \n",
       "                       10.0  0.10   41.480045  41.956175  42.426407  42.426407  \n",
       "                             0.25   24.007437  24.331598  24.494897  24.494897  \n",
       "                             0.50   13.859293  14.071247  14.142136  14.142136  \n",
       "                             0.75    8.001666   8.164966   8.164966   8.164966  \n",
       "                             0.90    4.714045   4.714045   4.714045   4.714045  \n",
       "                       50.0  0.10   42.426407  42.426407  42.426407  42.426407  \n",
       "                             0.25   24.494897  24.494897  24.494897  24.494897  \n",
       "                             0.50   14.142136  14.142136  14.142136  14.142136  \n",
       "                             0.75    8.164966   8.164966   8.164966   8.164966  \n",
       "                             0.90    4.714045   4.714045   4.714045   4.714045  "
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "grouped_df[\"w_bl_z_score\"].describe()"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### new metrics"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "507 507\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:25<00:00,  3.23s/it]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.92it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "507 507\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.55it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.91it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "507 507\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.55it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.88it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cohenrence score: baseline 0.6112307937892937, w/ bl 0.6077465531388684, no bl 0.6196773611817369\n"
     ]
    }
   ],
   "source": [
    "# coherence \n",
    "import sys\n",
    "sys.path.insert(0, \"..\")\n",
    "from metrics.coherence import get_coherence_score\n",
    "\n",
    "group = (True, 1, 2.0, 0.5)\n",
    "# group = (False, 1, 2.0, 0.5\n",
    "group_df = grouped_df.get_group(group)\n",
    "\n",
    "prefix_text = group_df[\"truncated_input\"].values.tolist()\n",
    "\n",
    "baseline_completion = group_df[\"baseline_completion\"].values.tolist()\n",
    "w_bl_output = group_df[\"w_bl_output\"].values.tolist()\n",
    "no_bl_output = group_df[\"no_bl_output\"].values.tolist()\n",
    "\n",
    "coherence_ref = get_coherence_score(prefix_text, baseline_completion)\n",
    "coherence_w_bl = get_coherence_score(prefix_text, w_bl_output)\n",
    "coherence_no_bl = get_coherence_score(prefix_text, no_bl_output)\n",
    "\n",
    "print(f\"cohenrence score: baseline {coherence_ref}, w/ bl {coherence_w_bl}, no bl {coherence_no_bl}\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "03/31/2023 14:25:23 - INFO - faiss.loader -   Loading faiss with AVX2 support.\n",
      "03/31/2023 14:25:23 - INFO - faiss.loader -   Successfully loaded faiss with AVX2 support.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 507, q_text: 507\n",
      "remaining p_text: 507, q_text: 507\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 507/507 [00:04<00:00, 118.70it/s]\n",
      "Featurizing q: 100%|██████████| 507/507 [00:04<00:00, 119.58it/s]\n",
      "WARNING clustering 1014 points to 51 centroids: please provide at least 1989 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 507, q_text: 507\n",
      "remaining p_text: 507, q_text: 507\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 507/507 [00:04<00:00, 124.46it/s]\n",
      "Featurizing q: 100%|██████████| 507/507 [00:04<00:00, 124.32it/s]\n",
      "WARNING clustering 1014 points to 51 centroids: please provide at least 1989 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.9199462059182815 0.8585088981213014\n"
     ]
    }
   ],
   "source": [
    "# MAUVE (https://github.com/XiangLi1999/ContrastiveDecoding)\n",
    "import sys\n",
    "sys.path.insert(0, \"..\")\n",
    "from metrics.mauve import get_mauve_score\n",
    "\n",
    "group = (True, 1, 2.0, 0.5)\n",
    "# group = (False, 1, 2.0, 0.5\n",
    "group_df = grouped_df.get_group(group)\n",
    "\n",
    "## first measure betwee baseline and output w/ watermark\n",
    "p_text = group_df[\"baseline_completion\"].values.tolist()\n",
    "q_text_w_bl = group_df[\"w_bl_output\"].values.tolist()\n",
    "q_text_no_bl = group_df[\"no_bl_output\"].values.tolist()\n",
    "\n",
    "mauve_w_bl = get_mauve_score(p_text, q_text_w_bl, max_len=128)\n",
    "mauve_no_bl = get_mauve_score(p_text, q_text_no_bl, max_len=128)\n",
    "\n",
    "print(mauve_w_bl, mauve_no_bl)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 505, q_text: 505\n",
      "remaining p_text: 505, q_text: 505\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 505/505 [00:04<00:00, 123.99it/s]\n",
      "Featurizing q: 100%|██████████| 505/505 [00:04<00:00, 123.65it/s]\n",
      "WARNING clustering 1010 points to 50 centroids: please provide at least 1950 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 505, q_text: 505\n",
      "remaining p_text: 505, q_text: 505\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 505/505 [00:04<00:00, 123.81it/s]\n",
      "Featurizing q: 100%|██████████| 505/505 [00:04<00:00, 123.38it/s]\n",
      "WARNING clustering 1010 points to 50 centroids: please provide at least 1950 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 505, q_text: 505\n",
      "remaining p_text: 505, q_text: 505\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 505/505 [00:04<00:00, 124.57it/s]\n",
      "Featurizing q: 100%|██████████| 505/505 [00:04<00:00, 122.60it/s]\n",
      "WARNING clustering 1010 points to 50 centroids: please provide at least 1950 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 505, q_text: 505\n",
      "remaining p_text: 505, q_text: 505\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 505/505 [00:04<00:00, 124.35it/s]\n",
      "Featurizing q: 100%|██████████| 505/505 [00:04<00:00, 121.59it/s]\n",
      "WARNING clustering 1010 points to 50 centroids: please provide at least 1950 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 507, q_text: 507\n",
      "remaining p_text: 507, q_text: 507\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 507/507 [00:04<00:00, 123.93it/s]\n",
      "Featurizing q: 100%|██████████| 507/507 [00:04<00:00, 121.60it/s]\n",
      "WARNING clustering 1014 points to 51 centroids: please provide at least 1989 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 507, q_text: 507\n",
      "remaining p_text: 507, q_text: 507\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 507/507 [00:04<00:00, 122.45it/s]\n",
      "Featurizing q: 100%|██████████| 507/507 [00:04<00:00, 122.27it/s]\n",
      "WARNING clustering 1014 points to 51 centroids: please provide at least 1989 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 505, q_text: 505\n",
      "remaining p_text: 505, q_text: 505\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 505/505 [00:04<00:00, 124.71it/s]\n",
      "Featurizing q: 100%|██████████| 505/505 [00:04<00:00, 124.41it/s]\n",
      "WARNING clustering 1010 points to 50 centroids: please provide at least 1950 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 505, q_text: 505\n",
      "remaining p_text: 505, q_text: 505\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 505/505 [00:04<00:00, 123.52it/s]\n",
      "Featurizing q: 100%|██████████| 505/505 [00:04<00:00, 123.34it/s]\n",
      "WARNING clustering 1010 points to 50 centroids: please provide at least 1950 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 507, q_text: 507\n",
      "remaining p_text: 507, q_text: 507\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 507/507 [00:04<00:00, 124.28it/s]\n",
      "Featurizing q: 100%|██████████| 507/507 [00:04<00:00, 124.39it/s]\n",
      "WARNING clustering 1014 points to 51 centroids: please provide at least 1989 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 507, q_text: 507\n",
      "remaining p_text: 507, q_text: 507\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 507/507 [00:04<00:00, 124.29it/s]\n",
      "Featurizing q: 100%|██████████| 507/507 [00:04<00:00, 122.24it/s]\n",
      "WARNING clustering 1014 points to 51 centroids: please provide at least 1989 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 504, q_text: 504\n",
      "remaining p_text: 504, q_text: 504\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 504/504 [00:04<00:00, 123.63it/s]\n",
      "Featurizing q: 100%|██████████| 504/504 [00:04<00:00, 122.39it/s]\n",
      "WARNING clustering 1008 points to 50 centroids: please provide at least 1950 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 504, q_text: 504\n",
      "remaining p_text: 504, q_text: 504\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 504/504 [00:04<00:00, 123.02it/s]\n",
      "Featurizing q: 100%|██████████| 504/504 [00:04<00:00, 121.99it/s]\n",
      "WARNING clustering 1008 points to 50 centroids: please provide at least 1950 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 503, q_text: 503\n",
      "remaining p_text: 503, q_text: 503\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 503/503 [00:04<00:00, 123.10it/s]\n",
      "Featurizing q: 100%|██████████| 503/503 [00:04<00:00, 123.80it/s]\n",
      "WARNING clustering 1006 points to 50 centroids: please provide at least 1950 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 503, q_text: 503\n",
      "remaining p_text: 503, q_text: 503\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 503/503 [00:04<00:00, 123.55it/s]\n",
      "Featurizing q: 100%|██████████| 503/503 [00:04<00:00, 124.51it/s]\n",
      "WARNING clustering 1006 points to 50 centroids: please provide at least 1950 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 506, q_text: 506\n",
      "remaining p_text: 506, q_text: 506\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 506/506 [00:04<00:00, 124.57it/s]\n",
      "Featurizing q: 100%|██████████| 506/506 [00:04<00:00, 124.17it/s]\n",
      "WARNING clustering 1012 points to 51 centroids: please provide at least 1989 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 506, q_text: 506\n",
      "remaining p_text: 506, q_text: 506\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 506/506 [00:04<00:00, 123.87it/s]\n",
      "Featurizing q: 100%|██████████| 506/506 [00:04<00:00, 124.50it/s]\n",
      "WARNING clustering 1012 points to 51 centroids: please provide at least 1989 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 507, q_text: 507\n",
      "remaining p_text: 507, q_text: 507\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 507/507 [00:04<00:00, 124.54it/s]\n",
      "Featurizing q: 100%|██████████| 507/507 [00:04<00:00, 124.73it/s]\n",
      "WARNING clustering 1014 points to 51 centroids: please provide at least 1989 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 507, q_text: 507\n",
      "remaining p_text: 507, q_text: 507\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 507/507 [00:04<00:00, 124.78it/s]\n",
      "Featurizing q: 100%|██████████| 507/507 [00:04<00:00, 124.63it/s]\n",
      "WARNING clustering 1014 points to 51 centroids: please provide at least 1989 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 504, q_text: 504\n",
      "remaining p_text: 504, q_text: 504\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 504/504 [00:04<00:00, 123.93it/s]\n",
      "Featurizing q: 100%|██████████| 504/504 [00:04<00:00, 123.36it/s]\n",
      "WARNING clustering 1008 points to 50 centroids: please provide at least 1950 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 504, q_text: 504\n",
      "remaining p_text: 504, q_text: 504\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 504/504 [00:04<00:00, 124.76it/s]\n",
      "Featurizing q: 100%|██████████| 504/504 [00:04<00:00, 124.51it/s]\n",
      "WARNING clustering 1008 points to 50 centroids: please provide at least 1950 training points\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>sampling</th>\n",
       "      <th>beams</th>\n",
       "      <th>gammas</th>\n",
       "      <th>deltas</th>\n",
       "      <th>no_watermark_mauve</th>\n",
       "      <th>watermark_mauve</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>True</td>\n",
       "      <td>1</td>\n",
       "      <td>0.90</td>\n",
       "      <td>2.0</td>\n",
       "      <td>0.923169</td>\n",
       "      <td>0.959667</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>True</td>\n",
       "      <td>1</td>\n",
       "      <td>0.75</td>\n",
       "      <td>2.0</td>\n",
       "      <td>0.939498</td>\n",
       "      <td>0.941566</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>True</td>\n",
       "      <td>1</td>\n",
       "      <td>0.50</td>\n",
       "      <td>2.0</td>\n",
       "      <td>0.858509</td>\n",
       "      <td>0.919946</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>True</td>\n",
       "      <td>1</td>\n",
       "      <td>0.25</td>\n",
       "      <td>2.0</td>\n",
       "      <td>0.947006</td>\n",
       "      <td>0.888785</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>True</td>\n",
       "      <td>1</td>\n",
       "      <td>0.10</td>\n",
       "      <td>2.0</td>\n",
       "      <td>0.937360</td>\n",
       "      <td>0.869803</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>True</td>\n",
       "      <td>1</td>\n",
       "      <td>0.50</td>\n",
       "      <td>0.1</td>\n",
       "      <td>0.911261</td>\n",
       "      <td>0.952374</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>True</td>\n",
       "      <td>1</td>\n",
       "      <td>0.50</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.916015</td>\n",
       "      <td>0.912770</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>True</td>\n",
       "      <td>1</td>\n",
       "      <td>0.50</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.912959</td>\n",
       "      <td>0.935294</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>True</td>\n",
       "      <td>1</td>\n",
       "      <td>0.50</td>\n",
       "      <td>2.0</td>\n",
       "      <td>0.858509</td>\n",
       "      <td>0.919946</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>True</td>\n",
       "      <td>1</td>\n",
       "      <td>0.50</td>\n",
       "      <td>5.0</td>\n",
       "      <td>0.964470</td>\n",
       "      <td>0.929753</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   sampling  beams  gammas  deltas  no_watermark_mauve  watermark_mauve\n",
       "0      True      1    0.90     2.0            0.923169         0.959667\n",
       "1      True      1    0.75     2.0            0.939498         0.941566\n",
       "2      True      1    0.50     2.0            0.858509         0.919946\n",
       "3      True      1    0.25     2.0            0.947006         0.888785\n",
       "4      True      1    0.10     2.0            0.937360         0.869803\n",
       "5      True      1    0.50     0.1            0.911261         0.952374\n",
       "6      True      1    0.50     0.5            0.916015         0.912770\n",
       "7      True      1    0.50     1.0            0.912959         0.935294\n",
       "8      True      1    0.50     2.0            0.858509         0.919946\n",
       "9      True      1    0.50     5.0            0.964470         0.929753"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# make MAUVE plot\n",
    "# Sampling\n",
    "group_list =(\n",
    "    (True, 1, 2.0, 0.9),\n",
    "    (True, 1, 2.0, 0.75),\n",
    "    (True, 1, 2.0, 0.5),\n",
    "    (True, 1, 2.0, 0.25),\n",
    "    (True, 1, 2.0, 0.1),\n",
    "\n",
    "    (True, 1, 0.1, 0.5),\n",
    "    (True, 1, 0.5, 0.5),\n",
    "    (True, 1, 1.0, 0.5),\n",
    "    (True, 1, 2.0, 0.5),\n",
    "    (True, 1, 5.0, 0.5),\n",
    ")\n",
    "\n",
    "sampling, beams, gammas, deltas = [], [], [], []\n",
    "# baseline_mauve = []\n",
    "no_watermark_mauve = []\n",
    "watermark_mauve = []\n",
    "\n",
    "for idx, group in enumerate(group_list):\n",
    "    group_df = grouped_df.get_group(group)\n",
    "\n",
    "    sampling.append(group[0])\n",
    "    beams.append(group[1])\n",
    "    deltas.append(group[2])\n",
    "    gammas.append(group[3])\n",
    "    ## get mauve scores\n",
    "    p_text = group_df[\"baseline_completion\"].values.tolist()\n",
    "    q_text_w_bl = group_df[\"w_bl_output\"].values.tolist()\n",
    "    q_text_no_bl = group_df[\"no_bl_output\"].values.tolist()\n",
    "\n",
    "    watermark_mauve.append(get_mauve_score(p_text, q_text_w_bl, max_len=128))\n",
    "    no_watermark_mauve.append(get_mauve_score(p_text, q_text_no_bl, max_len=128))\n",
    "\n",
    "viz_df = pd.DataFrame()\n",
    "\n",
    "\n",
    "viz_df[\"sampling\"] = sampling\n",
    "viz_df[\"beams\"] = beams\n",
    "viz_df[\"gammas\"] = gammas\n",
    "viz_df[\"deltas\"] = deltas\n",
    "\n",
    "viz_df['no_watermark_mauve'] = no_watermark_mauve\n",
    "viz_df['watermark_mauve'] = watermark_mauve\n",
    "\n",
    "viz_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "03/31/2023 14:35:03 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:03 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:03 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:04 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:04 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:04 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:04 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:04 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:04 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:04 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:04 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:04 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:04 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:04 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:04 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:04 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:04 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:04 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:04 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:04 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:04 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:05 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:05 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:05 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:05 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:05 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:05 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:05 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:05 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:05 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:05 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:05 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:05 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:05 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:05 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:05 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:05 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:05 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:05 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:05 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:05 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:05 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:05 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:05 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:05 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:05 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:05 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:05 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:06 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:35:07 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 800x300 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "gammas = viz_df[\"gammas\"].values.tolist()\n",
    "deltas = viz_df[\"deltas\"].values.tolist()\n",
    "\n",
    "no_watermark_mauve = viz_df[\"no_watermark_mauve\"].values.tolist()\n",
    "watermark_mauve = viz_df[\"watermark_mauve\"].values.tolist()\n",
    "\n",
    "fig, axs = plt.subplots(ncols=2, nrows=1, figsize=(8,3), sharey=True)\n",
    "slice_idx = len(no_watermark_mauve)//2\n",
    "\n",
    "plt.subplot(1, 2, 1)\n",
    "plt.subplot(1, 2, 1)\n",
    "plt.plot(gammas[:slice_idx], no_watermark_mauve[:slice_idx], label=\"no watermark\")\n",
    "plt.plot(gammas[:slice_idx], watermark_mauve[:slice_idx], label=\"watermark\")\n",
    "plt.xticks(gammas[:slice_idx])\n",
    "plt.xlim(0, 1)\n",
    "# reverse x axis\n",
    "axs[0].invert_xaxis()\n",
    "plt.xlabel(\"gamma\")\n",
    "plt.ylabel(\"mauve score\")\n",
    "\n",
    "plt.subplot(1, 2, 2)\n",
    "plt.plot(deltas[slice_idx:], no_watermark_mauve[slice_idx:], label=\"no watermark\")\n",
    "plt.plot(deltas[slice_idx:], watermark_mauve[slice_idx:], label=\"watermark\")\n",
    "plt.xticks(deltas[slice_idx:])\n",
    "plt.xlim(0, 5.1)\n",
    "plt.xlabel(\"delta\")\n",
    "plt.ylabel(\"mauve score\")\n",
    "\n",
    "\n",
    "# legend to right of both charts\n",
    "plt.legend(bbox_to_anchor=(1.05, 1), loc='upper left', borderaxespad=0.)\n",
    "plt.tight_layout()\n",
    "plt.savefig(f\"{OUTPUT_DIR}/sampling_mauve_score.png\")\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 497, q_text: 497\n",
      "remaining p_text: 497, q_text: 497\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 497/497 [00:04<00:00, 124.06it/s]\n",
      "Featurizing q: 100%|██████████| 497/497 [00:03<00:00, 124.56it/s]\n",
      "WARNING clustering 994 points to 50 centroids: please provide at least 1950 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 497, q_text: 497\n",
      "remaining p_text: 497, q_text: 497\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 497/497 [00:03<00:00, 124.61it/s]\n",
      "Featurizing q: 100%|██████████| 497/497 [00:03<00:00, 124.76it/s]\n",
      "WARNING clustering 994 points to 50 centroids: please provide at least 1950 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 496, q_text: 496\n",
      "remaining p_text: 496, q_text: 496\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 496/496 [00:03<00:00, 124.34it/s]\n",
      "Featurizing q: 100%|██████████| 496/496 [00:03<00:00, 124.16it/s]\n",
      "WARNING clustering 992 points to 50 centroids: please provide at least 1950 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 496, q_text: 496\n",
      "remaining p_text: 496, q_text: 496\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 496/496 [00:04<00:00, 123.93it/s]\n",
      "Featurizing q: 100%|██████████| 496/496 [00:03<00:00, 124.36it/s]\n",
      "WARNING clustering 992 points to 50 centroids: please provide at least 1950 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 497, q_text: 497\n",
      "remaining p_text: 497, q_text: 497\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 497/497 [00:04<00:00, 123.78it/s]\n",
      "Featurizing q: 100%|██████████| 497/497 [00:04<00:00, 124.25it/s]\n",
      "WARNING clustering 994 points to 50 centroids: please provide at least 1950 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 497, q_text: 497\n",
      "remaining p_text: 497, q_text: 497\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 497/497 [00:03<00:00, 124.37it/s]\n",
      "Featurizing q: 100%|██████████| 497/497 [00:04<00:00, 124.03it/s]\n",
      "WARNING clustering 994 points to 50 centroids: please provide at least 1950 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 495, q_text: 495\n",
      "remaining p_text: 495, q_text: 495\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 495/495 [00:04<00:00, 123.09it/s]\n",
      "Featurizing q: 100%|██████████| 495/495 [00:04<00:00, 123.24it/s]\n",
      "WARNING clustering 990 points to 50 centroids: please provide at least 1950 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 495, q_text: 495\n",
      "remaining p_text: 495, q_text: 495\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 495/495 [00:03<00:00, 124.45it/s]\n",
      "Featurizing q: 100%|██████████| 495/495 [00:03<00:00, 124.41it/s]\n",
      "WARNING clustering 990 points to 50 centroids: please provide at least 1950 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 495, q_text: 495\n",
      "remaining p_text: 495, q_text: 495\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 495/495 [00:03<00:00, 123.82it/s]\n",
      "Featurizing q: 100%|██████████| 495/495 [00:03<00:00, 124.22it/s]\n",
      "WARNING clustering 990 points to 50 centroids: please provide at least 1950 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 495, q_text: 495\n",
      "remaining p_text: 495, q_text: 495\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 495/495 [00:03<00:00, 124.36it/s]\n",
      "Featurizing q: 100%|██████████| 495/495 [00:03<00:00, 124.40it/s]\n",
      "WARNING clustering 990 points to 50 centroids: please provide at least 1950 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 500, q_text: 500\n",
      "remaining p_text: 500, q_text: 500\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 500/500 [00:04<00:00, 124.63it/s]\n",
      "Featurizing q: 100%|██████████| 500/500 [00:04<00:00, 124.10it/s]\n",
      "WARNING clustering 1000 points to 50 centroids: please provide at least 1950 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 500, q_text: 500\n",
      "remaining p_text: 500, q_text: 500\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 500/500 [00:04<00:00, 123.75it/s]\n",
      "Featurizing q: 100%|██████████| 500/500 [00:04<00:00, 124.05it/s]\n",
      "WARNING clustering 1000 points to 50 centroids: please provide at least 1950 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 504, q_text: 504\n",
      "remaining p_text: 504, q_text: 504\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 504/504 [00:04<00:00, 124.25it/s]\n",
      "Featurizing q: 100%|██████████| 504/504 [00:04<00:00, 123.97it/s]\n",
      "WARNING clustering 1008 points to 50 centroids: please provide at least 1950 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 504, q_text: 504\n",
      "remaining p_text: 504, q_text: 504\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 504/504 [00:04<00:00, 124.47it/s]\n",
      "Featurizing q: 100%|██████████| 504/504 [00:04<00:00, 124.27it/s]\n",
      "WARNING clustering 1008 points to 50 centroids: please provide at least 1950 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 506, q_text: 506\n",
      "remaining p_text: 506, q_text: 506\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 506/506 [00:04<00:00, 123.98it/s]\n",
      "Featurizing q: 100%|██████████| 506/506 [00:04<00:00, 124.32it/s]\n",
      "WARNING clustering 1012 points to 51 centroids: please provide at least 1989 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 506, q_text: 506\n",
      "remaining p_text: 506, q_text: 506\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 506/506 [00:04<00:00, 123.78it/s]\n",
      "Featurizing q: 100%|██████████| 506/506 [00:04<00:00, 123.82it/s]\n",
      "WARNING clustering 1012 points to 51 centroids: please provide at least 1989 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 504, q_text: 504\n",
      "remaining p_text: 504, q_text: 504\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 504/504 [00:04<00:00, 124.06it/s]\n",
      "Featurizing q: 100%|██████████| 504/504 [00:04<00:00, 124.06it/s]\n",
      "WARNING clustering 1008 points to 50 centroids: please provide at least 1950 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 504, q_text: 504\n",
      "remaining p_text: 504, q_text: 504\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 504/504 [00:04<00:00, 124.24it/s]\n",
      "Featurizing q: 100%|██████████| 504/504 [00:04<00:00, 124.33it/s]\n",
      "WARNING clustering 1008 points to 50 centroids: please provide at least 1950 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 507, q_text: 507\n",
      "remaining p_text: 507, q_text: 507\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 507/507 [00:04<00:00, 124.04it/s]\n",
      "Featurizing q: 100%|██████████| 507/507 [00:04<00:00, 124.27it/s]\n",
      "WARNING clustering 1014 points to 51 centroids: please provide at least 1989 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 507, q_text: 507\n",
      "remaining p_text: 507, q_text: 507\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 507/507 [00:04<00:00, 123.80it/s]\n",
      "Featurizing q: 100%|██████████| 507/507 [00:04<00:00, 123.28it/s]\n",
      "WARNING clustering 1014 points to 51 centroids: please provide at least 1989 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 501, q_text: 501\n",
      "remaining p_text: 501, q_text: 501\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 501/501 [00:04<00:00, 123.28it/s]\n",
      "Featurizing q: 100%|██████████| 501/501 [00:04<00:00, 122.96it/s]\n",
      "WARNING clustering 1002 points to 50 centroids: please provide at least 1950 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 501, q_text: 501\n",
      "remaining p_text: 501, q_text: 501\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 501/501 [00:04<00:00, 123.86it/s]\n",
      "Featurizing q: 100%|██████████| 501/501 [00:04<00:00, 124.21it/s]\n",
      "WARNING clustering 1002 points to 50 centroids: please provide at least 1950 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 503, q_text: 503\n",
      "remaining p_text: 503, q_text: 503\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 503/503 [00:04<00:00, 123.74it/s]\n",
      "Featurizing q: 100%|██████████| 503/503 [00:04<00:00, 123.94it/s]\n",
      "WARNING clustering 1006 points to 50 centroids: please provide at least 1950 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 503, q_text: 503\n",
      "remaining p_text: 503, q_text: 503\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 503/503 [00:04<00:00, 124.28it/s]\n",
      "Featurizing q: 100%|██████████| 503/503 [00:04<00:00, 124.22it/s]\n",
      "WARNING clustering 1006 points to 50 centroids: please provide at least 1950 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 501, q_text: 501\n",
      "remaining p_text: 501, q_text: 501\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 501/501 [00:04<00:00, 123.25it/s]\n",
      "Featurizing q: 100%|██████████| 501/501 [00:04<00:00, 122.84it/s]\n",
      "WARNING clustering 1002 points to 50 centroids: please provide at least 1950 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 501, q_text: 501\n",
      "remaining p_text: 501, q_text: 501\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 501/501 [00:04<00:00, 124.09it/s]\n",
      "Featurizing q: 100%|██████████| 501/501 [00:04<00:00, 123.56it/s]\n",
      "WARNING clustering 1002 points to 50 centroids: please provide at least 1950 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 502, q_text: 502\n",
      "remaining p_text: 502, q_text: 502\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 502/502 [00:04<00:00, 124.18it/s]\n",
      "Featurizing q: 100%|██████████| 502/502 [00:04<00:00, 124.30it/s]\n",
      "WARNING clustering 1004 points to 50 centroids: please provide at least 1950 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 502, q_text: 502\n",
      "remaining p_text: 502, q_text: 502\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 502/502 [00:04<00:00, 123.92it/s]\n",
      "Featurizing q: 100%|██████████| 502/502 [00:04<00:00, 123.62it/s]\n",
      "WARNING clustering 1004 points to 50 centroids: please provide at least 1950 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 498, q_text: 498\n",
      "remaining p_text: 498, q_text: 498\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 498/498 [00:04<00:00, 124.12it/s]\n",
      "Featurizing q: 100%|██████████| 498/498 [00:04<00:00, 124.05it/s]\n",
      "WARNING clustering 996 points to 50 centroids: please provide at least 1950 training points\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial p_text: 498, q_text: 498\n",
      "remaining p_text: 498, q_text: 498\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Featurizing p: 100%|██████████| 498/498 [00:04<00:00, 123.96it/s]\n",
      "Featurizing q: 100%|██████████| 498/498 [00:04<00:00, 124.00it/s]\n",
      "WARNING clustering 996 points to 50 centroids: please provide at least 1950 training points\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>sampling</th>\n",
       "      <th>beams</th>\n",
       "      <th>gammas</th>\n",
       "      <th>deltas</th>\n",
       "      <th>no_watermark_mauve</th>\n",
       "      <th>watermark_mauve</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>False</td>\n",
       "      <td>1</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.1</td>\n",
       "      <td>0.225939</td>\n",
       "      <td>0.232342</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>False</td>\n",
       "      <td>1</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.239336</td>\n",
       "      <td>0.221264</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>False</td>\n",
       "      <td>1</td>\n",
       "      <td>0.5</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.227232</td>\n",
       "      <td>0.260508</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>False</td>\n",
       "      <td>1</td>\n",
       "      <td>0.5</td>\n",
       "      <td>2.0</td>\n",
       "      <td>0.247442</td>\n",
       "      <td>0.263664</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>False</td>\n",
       "      <td>1</td>\n",
       "      <td>0.5</td>\n",
       "      <td>5.0</td>\n",
       "      <td>0.238256</td>\n",
       "      <td>0.188275</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>False</td>\n",
       "      <td>4</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.1</td>\n",
       "      <td>0.736922</td>\n",
       "      <td>0.798888</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>False</td>\n",
       "      <td>4</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.719751</td>\n",
       "      <td>0.675957</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>False</td>\n",
       "      <td>4</td>\n",
       "      <td>0.5</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.727009</td>\n",
       "      <td>0.652992</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>False</td>\n",
       "      <td>4</td>\n",
       "      <td>0.5</td>\n",
       "      <td>2.0</td>\n",
       "      <td>0.678345</td>\n",
       "      <td>0.674693</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>False</td>\n",
       "      <td>4</td>\n",
       "      <td>0.5</td>\n",
       "      <td>5.0</td>\n",
       "      <td>0.680771</td>\n",
       "      <td>0.675959</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>False</td>\n",
       "      <td>8</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.1</td>\n",
       "      <td>0.709712</td>\n",
       "      <td>0.679087</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>False</td>\n",
       "      <td>8</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.736322</td>\n",
       "      <td>0.712470</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>False</td>\n",
       "      <td>8</td>\n",
       "      <td>0.5</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.660935</td>\n",
       "      <td>0.606752</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>False</td>\n",
       "      <td>8</td>\n",
       "      <td>0.5</td>\n",
       "      <td>2.0</td>\n",
       "      <td>0.696546</td>\n",
       "      <td>0.585997</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>False</td>\n",
       "      <td>8</td>\n",
       "      <td>0.5</td>\n",
       "      <td>5.0</td>\n",
       "      <td>0.687781</td>\n",
       "      <td>0.596150</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "    sampling  beams  gammas  deltas  no_watermark_mauve  watermark_mauve\n",
       "0      False      1     0.5     0.1            0.225939         0.232342\n",
       "1      False      1     0.5     0.5            0.239336         0.221264\n",
       "2      False      1     0.5     1.0            0.227232         0.260508\n",
       "3      False      1     0.5     2.0            0.247442         0.263664\n",
       "4      False      1     0.5     5.0            0.238256         0.188275\n",
       "5      False      4     0.5     0.1            0.736922         0.798888\n",
       "6      False      4     0.5     0.5            0.719751         0.675957\n",
       "7      False      4     0.5     1.0            0.727009         0.652992\n",
       "8      False      4     0.5     2.0            0.678345         0.674693\n",
       "9      False      4     0.5     5.0            0.680771         0.675959\n",
       "10     False      8     0.5     0.1            0.709712         0.679087\n",
       "11     False      8     0.5     0.5            0.736322         0.712470\n",
       "12     False      8     0.5     1.0            0.660935         0.606752\n",
       "13     False      8     0.5     2.0            0.696546         0.585997\n",
       "14     False      8     0.5     5.0            0.687781         0.596150"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Greedy\n",
    "group_list =(\n",
    "    (False, 1, 0.1, 0.5),\n",
    "    (False, 1, 0.5, 0.5),\n",
    "    (False, 1, 1.0, 0.5),\n",
    "    (False, 1, 2.0, 0.5),\n",
    "    (False, 1, 5.0, 0.5),\n",
    "\n",
    "    (False, 4, 0.1, 0.5),\n",
    "    (False, 4, 0.5, 0.5),\n",
    "    (False, 4, 1.0, 0.5),\n",
    "    (False, 4, 2.0, 0.5),\n",
    "    (False, 4, 5.0, 0.5),\n",
    "\n",
    "    (False, 8, 0.1, 0.5),\n",
    "    (False, 8, 0.5, 0.5),\n",
    "    (False, 8, 1.0, 0.5),\n",
    "    (False, 8, 2.0, 0.5),\n",
    "    (False, 8, 5.0, 0.5),\n",
    ")\n",
    "\n",
    "sampling, beams, gammas, deltas = [], [], [], []\n",
    "# baseline_mauve = []\n",
    "no_watermark_mauve = []\n",
    "watermark_mauve = []\n",
    "\n",
    "for idx, group in enumerate(group_list):\n",
    "    group_df = grouped_df.get_group(group)\n",
    "\n",
    "    sampling.append(group[0])\n",
    "    beams.append(group[1])\n",
    "    deltas.append(group[2])\n",
    "    gammas.append(group[3])\n",
    "    ## get mauve scores\n",
    "    p_text = group_df[\"baseline_completion\"].values.tolist()\n",
    "    q_text_w_bl = group_df[\"w_bl_output\"].values.tolist()\n",
    "    q_text_no_bl = group_df[\"no_bl_output\"].values.tolist()\n",
    "\n",
    "    watermark_mauve.append(get_mauve_score(p_text, q_text_w_bl, max_len=128))\n",
    "    no_watermark_mauve.append(get_mauve_score(p_text, q_text_no_bl, max_len=128))\n",
    "\n",
    "viz_df_greedy = pd.DataFrame()\n",
    "\n",
    "\n",
    "viz_df_greedy[\"sampling\"] = sampling\n",
    "viz_df_greedy[\"beams\"] = beams\n",
    "viz_df_greedy[\"gammas\"] = gammas\n",
    "viz_df_greedy[\"deltas\"] = deltas\n",
    "\n",
    "viz_df_greedy['no_watermark_mauve'] = no_watermark_mauve\n",
    "viz_df_greedy['watermark_mauve'] = watermark_mauve\n",
    "\n",
    "viz_df_greedy\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:45 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 14:48:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1200x300 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "beams = viz_df_greedy[\"beams\"].values.tolist()\n",
    "deltas = viz_df_greedy[\"deltas\"].values.tolist()\n",
    "\n",
    "no_watermark_mauve = viz_df_greedy[\"no_watermark_mauve\"].values.tolist()\n",
    "watermark_mauve = viz_df_greedy[\"watermark_mauve\"].values.tolist() \n",
    "\n",
    "fig, axs = plt.subplots(ncols=3, nrows=1, figsize=(12,3), sharey=True)\n",
    "slice_idx = len(no_watermark_mauve)//3\n",
    "\n",
    "plt.subplot(1, 3, 1)\n",
    "plt.plot(deltas[:slice_idx], no_watermark_mauve[:slice_idx], label=\"no watermark\")\n",
    "plt.plot(deltas[:slice_idx], watermark_mauve[:slice_idx], label=\"watermark\")\n",
    "plt.xticks(deltas[:slice_idx])\n",
    "plt.xlim(0, 5.1)\n",
    "plt.title(\"Number of beams = 1\")\n",
    "plt.xlabel(\"deltas\")\n",
    "plt.ylabel(\"mauve score\")\n",
    "\n",
    "plt.subplot(1, 3, 2)\n",
    "plt.plot(deltas[slice_idx:slice_idx*2], no_watermark_mauve[slice_idx:slice_idx*2], label=\"no watermark\")\n",
    "plt.plot(deltas[slice_idx:slice_idx*2], watermark_mauve[slice_idx:slice_idx*2], label=\"watermark\")\n",
    "plt.xticks(deltas[slice_idx:slice_idx*2])\n",
    "plt.xlim(0, 5.1)\n",
    "plt.title(\"Number of beams = 4\")\n",
    "plt.xlabel(\"deltas\")\n",
    "plt.ylabel(\"mauve score\")\n",
    "\n",
    "plt.subplot(1, 3, 3)\n",
    "plt.plot(deltas[slice_idx*2:], no_watermark_mauve[slice_idx*2:], label=\"no watermark\")\n",
    "plt.plot(deltas[slice_idx*2:], watermark_mauve[slice_idx*2:], label=\"watermark\")\n",
    "plt.xticks(deltas[slice_idx*2:])\n",
    "plt.xlim(0, 5.1)\n",
    "plt.title(\"Number of beams = 8\")\n",
    "plt.xlabel(\"delta\")\n",
    "plt.ylabel(\"mauve score\")\n",
    "\n",
    "# legend to right of both charts\n",
    "plt.legend(bbox_to_anchor=(1.05, 1), loc='upper left', borderaxespad=0.)\n",
    "plt.tight_layout()\n",
    "plt.savefig(f\"{OUTPUT_DIR}/beams_mauve_score.png\")\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "505 505\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.73it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  5.05it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "505 505\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.65it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.99it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "505 505\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.61it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.95it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "505 505\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.61it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.93it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "505 505\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.54it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.97it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "505 505\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.55it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.86it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "507 507\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.46it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.86it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "507 507\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.49it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.75it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "507 507\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.44it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.77it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "505 505\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.33it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.76it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "505 505\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.40it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.77it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "505 505\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.43it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.67it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "507 507\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.28it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.69it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "507 507\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.30it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.64it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "507 507\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.26it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.58it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "504 504\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.32it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.63it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "504 504\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.29it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.64it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "504 504\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.29it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.60it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "503 503\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.27it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.64it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "503 503\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.28it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.57it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "503 503\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.26it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.62it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "506 506\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.21it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.52it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "506 506\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.24it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.59it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "506 506\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.20it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.51it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "507 507\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.21it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.51it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "507 507\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.21it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.54it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "507 507\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.18it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.57it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "504 504\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.23it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.56it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "504 504\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.23it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.56it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "504 504\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.26it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.53it/s]\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>sampling</th>\n",
       "      <th>beams</th>\n",
       "      <th>gammas</th>\n",
       "      <th>deltas</th>\n",
       "      <th>baseline_coherence</th>\n",
       "      <th>watermark_coherence</th>\n",
       "      <th>no_watermark_coherence</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>True</td>\n",
       "      <td>1</td>\n",
       "      <td>0.90</td>\n",
       "      <td>2.0</td>\n",
       "      <td>0.614041</td>\n",
       "      <td>0.626746</td>\n",
       "      <td>0.617203</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>True</td>\n",
       "      <td>1</td>\n",
       "      <td>0.75</td>\n",
       "      <td>2.0</td>\n",
       "      <td>0.610991</td>\n",
       "      <td>0.620250</td>\n",
       "      <td>0.618411</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>True</td>\n",
       "      <td>1</td>\n",
       "      <td>0.50</td>\n",
       "      <td>2.0</td>\n",
       "      <td>0.611231</td>\n",
       "      <td>0.607747</td>\n",
       "      <td>0.619677</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>True</td>\n",
       "      <td>1</td>\n",
       "      <td>0.25</td>\n",
       "      <td>2.0</td>\n",
       "      <td>0.607566</td>\n",
       "      <td>0.596032</td>\n",
       "      <td>0.606140</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>True</td>\n",
       "      <td>1</td>\n",
       "      <td>0.10</td>\n",
       "      <td>2.0</td>\n",
       "      <td>0.609115</td>\n",
       "      <td>0.600189</td>\n",
       "      <td>0.609934</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>True</td>\n",
       "      <td>1</td>\n",
       "      <td>0.50</td>\n",
       "      <td>0.1</td>\n",
       "      <td>0.617045</td>\n",
       "      <td>0.612604</td>\n",
       "      <td>0.629051</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>True</td>\n",
       "      <td>1</td>\n",
       "      <td>0.50</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.620293</td>\n",
       "      <td>0.622709</td>\n",
       "      <td>0.624392</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>True</td>\n",
       "      <td>1</td>\n",
       "      <td>0.50</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.617551</td>\n",
       "      <td>0.622855</td>\n",
       "      <td>0.623764</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>True</td>\n",
       "      <td>1</td>\n",
       "      <td>0.50</td>\n",
       "      <td>2.0</td>\n",
       "      <td>0.611231</td>\n",
       "      <td>0.607747</td>\n",
       "      <td>0.619677</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>True</td>\n",
       "      <td>1</td>\n",
       "      <td>0.50</td>\n",
       "      <td>5.0</td>\n",
       "      <td>0.616102</td>\n",
       "      <td>0.597489</td>\n",
       "      <td>0.616284</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   sampling  beams  gammas  deltas  baseline_coherence  watermark_coherence  \\\n",
       "0      True      1    0.90     2.0            0.614041             0.626746   \n",
       "1      True      1    0.75     2.0            0.610991             0.620250   \n",
       "2      True      1    0.50     2.0            0.611231             0.607747   \n",
       "3      True      1    0.25     2.0            0.607566             0.596032   \n",
       "4      True      1    0.10     2.0            0.609115             0.600189   \n",
       "5      True      1    0.50     0.1            0.617045             0.612604   \n",
       "6      True      1    0.50     0.5            0.620293             0.622709   \n",
       "7      True      1    0.50     1.0            0.617551             0.622855   \n",
       "8      True      1    0.50     2.0            0.611231             0.607747   \n",
       "9      True      1    0.50     5.0            0.616102             0.597489   \n",
       "\n",
       "   no_watermark_coherence  \n",
       "0                0.617203  \n",
       "1                0.618411  \n",
       "2                0.619677  \n",
       "3                0.606140  \n",
       "4                0.609934  \n",
       "5                0.629051  \n",
       "6                0.624392  \n",
       "7                0.623764  \n",
       "8                0.619677  \n",
       "9                0.616284  "
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# make coherence plot\n",
    "# Sampling\n",
    "group_list =(\n",
    "    (True, 1, 2.0, 0.9),\n",
    "    (True, 1, 2.0, 0.75),\n",
    "    (True, 1, 2.0, 0.5),\n",
    "    (True, 1, 2.0, 0.25),\n",
    "    (True, 1, 2.0, 0.1),\n",
    "\n",
    "    (True, 1, 0.1, 0.5),\n",
    "    (True, 1, 0.5, 0.5),\n",
    "    (True, 1, 1.0, 0.5),\n",
    "    (True, 1, 2.0, 0.5),\n",
    "    (True, 1, 5.0, 0.5),\n",
    ")\n",
    "\n",
    "sampling, beams, gammas, deltas = [], [], [], []\n",
    "baseline_coherence = []\n",
    "watermark_coherence = []\n",
    "no_watermark_coherence = []\n",
    "\n",
    "for idx, group in enumerate(group_list):\n",
    "    group_df = grouped_df.get_group(group)\n",
    "\n",
    "    sampling.append(group[0])\n",
    "    beams.append(group[1])\n",
    "    deltas.append(group[2])\n",
    "    gammas.append(group[3])\n",
    "    ## get coherence scores\n",
    "    prefix_text = group_df[\"truncated_input\"].values.tolist()\n",
    "\n",
    "    baseline_completion = group_df[\"baseline_completion\"].values.tolist()\n",
    "    w_bl_output = group_df[\"w_bl_output\"].values.tolist()\n",
    "    no_bl_output = group_df[\"no_bl_output\"].values.tolist()\n",
    "\n",
    "    baseline_coherence.append(get_coherence_score(prefix_text, baseline_completion))\n",
    "    watermark_coherence.append(get_coherence_score(prefix_text, w_bl_output))\n",
    "    no_watermark_coherence.append(get_coherence_score(prefix_text, no_bl_output))\n",
    "\n",
    "viz_df = pd.DataFrame()\n",
    "\n",
    "\n",
    "viz_df[\"sampling\"] = sampling\n",
    "viz_df[\"beams\"] = beams\n",
    "viz_df[\"gammas\"] = gammas\n",
    "viz_df[\"deltas\"] = deltas\n",
    "\n",
    "viz_df['baseline_coherence'] = baseline_coherence\n",
    "viz_df['watermark_coherence'] = watermark_coherence\n",
    "viz_df['no_watermark_coherence'] = no_watermark_coherence\n",
    "\n",
    "viz_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:12:46 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 800x300 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "gammas = viz_df[\"gammas\"].values.tolist()\n",
    "deltas = viz_df[\"deltas\"].values.tolist()\n",
    "\n",
    "baseline_coherence = viz_df[\"baseline_coherence\"].values.tolist()\n",
    "watermark_coherence = viz_df[\"watermark_coherence\"].values.tolist()\n",
    "no_watermark_coherence = viz_df[\"no_watermark_coherence\"].values.tolist()\n",
    "\n",
    "fig, axs = plt.subplots(ncols=2, nrows=1, figsize=(8,3), sharey=True)\n",
    "slice_idx = len(baseline_coherence)//2\n",
    "\n",
    "plt.subplot(1, 2, 1)\n",
    "plt.subplot(1, 2, 1)\n",
    "plt.plot(gammas[:slice_idx], baseline_coherence[:slice_idx], label=\"baseline\")\n",
    "plt.plot(gammas[:slice_idx], no_watermark_coherence[:slice_idx], label=\"no watermark\")\n",
    "plt.plot(gammas[:slice_idx], watermark_coherence[:slice_idx], label=\"watermark\")\n",
    "plt.xticks(gammas[:slice_idx])\n",
    "plt.xlim(0, 1)\n",
    "# reverse x axis\n",
    "axs[0].invert_xaxis()\n",
    "plt.xlabel(\"gamma\")\n",
    "plt.ylabel(\"coherence\")\n",
    "\n",
    "plt.subplot(1, 2, 2)\n",
    "plt.plot(deltas[slice_idx:], baseline_coherence[slice_idx:], label=\"baseline\")\n",
    "plt.plot(deltas[slice_idx:], no_watermark_coherence[slice_idx:], label=\"no watermark\")\n",
    "plt.plot(deltas[slice_idx:], watermark_coherence[slice_idx:], label=\"watermark\")\n",
    "plt.xticks(deltas[slice_idx:])\n",
    "plt.xlim(0, 5.1)\n",
    "plt.xlabel(\"delta\")\n",
    "plt.ylabel(\"coherence\")\n",
    "\n",
    "\n",
    "# legend to right of both charts\n",
    "plt.legend(bbox_to_anchor=(1.05, 1), loc='upper left', borderaxespad=0.)\n",
    "plt.tight_layout()\n",
    "plt.savefig(f\"{OUTPUT_DIR}/sampling_coherence_score.png\")\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "497 497\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.72it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  5.08it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "497 497\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.70it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  5.03it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "497 497\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.63it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  5.03it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "496 496\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.77it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  5.03it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "496 496\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.61it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  5.05it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "496 496\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.70it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.99it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "497 497\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.57it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.92it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "497 497\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.28it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "497 497\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.56it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.83it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "495 495\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.41it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "495 495\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.59it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.86it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "495 495\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.50it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.76it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "495 495\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.32it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.68it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "495 495\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.43it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.75it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "495 495\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.47it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.77it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "500 500\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.41it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.69it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "500 500\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.42it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.69it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "500 500\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.40it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.68it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "504 504\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.20it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.61it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "504 504\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.37it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.65it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "504 504\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.32it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.60it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "506 506\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.31it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.57it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "506 506\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.28it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.60it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "506 506\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.26it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.58it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "504 504\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.27it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.58it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "504 504\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.30it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.62it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "504 504\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.29it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.58it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "507 507\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.20it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.49it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "507 507\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.22it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.54it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "507 507\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.24it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.56it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "501 501\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.27it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.57it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "501 501\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.28it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.57it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "501 501\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.29it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.59it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "503 503\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.29it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.52it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "503 503\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.23it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.56it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "503 503\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.28it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.54it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "501 501\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.28it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.56it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "501 501\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.28it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.58it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "501 501\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.26it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.57it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "502 502\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.25it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.57it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "502 502\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.25it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.58it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "502 502\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.26it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.54it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "498 498\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.29it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.54it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "498 498\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.27it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.56it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "498 498\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 8/8 [00:01<00:00,  4.29it/s]\n",
      "100%|██████████| 8/8 [00:01<00:00,  4.57it/s]\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>sampling</th>\n",
       "      <th>beams</th>\n",
       "      <th>gammas</th>\n",
       "      <th>deltas</th>\n",
       "      <th>baseline_coherence</th>\n",
       "      <th>watermark_coherence</th>\n",
       "      <th>no_watermark_coherence</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>False</td>\n",
       "      <td>1</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.1</td>\n",
       "      <td>0.614911</td>\n",
       "      <td>0.557207</td>\n",
       "      <td>0.565086</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>False</td>\n",
       "      <td>1</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.613323</td>\n",
       "      <td>0.572616</td>\n",
       "      <td>0.566163</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>False</td>\n",
       "      <td>1</td>\n",
       "      <td>0.5</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.613967</td>\n",
       "      <td>0.568145</td>\n",
       "      <td>0.561886</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>False</td>\n",
       "      <td>1</td>\n",
       "      <td>0.5</td>\n",
       "      <td>2.0</td>\n",
       "      <td>0.613299</td>\n",
       "      <td>0.564281</td>\n",
       "      <td>0.563407</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>False</td>\n",
       "      <td>1</td>\n",
       "      <td>0.5</td>\n",
       "      <td>5.0</td>\n",
       "      <td>0.616185</td>\n",
       "      <td>0.551181</td>\n",
       "      <td>0.566810</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>False</td>\n",
       "      <td>4</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.1</td>\n",
       "      <td>0.613063</td>\n",
       "      <td>0.592225</td>\n",
       "      <td>0.591852</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>False</td>\n",
       "      <td>4</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.610608</td>\n",
       "      <td>0.584787</td>\n",
       "      <td>0.587506</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>False</td>\n",
       "      <td>4</td>\n",
       "      <td>0.5</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.608079</td>\n",
       "      <td>0.581858</td>\n",
       "      <td>0.579531</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>False</td>\n",
       "      <td>4</td>\n",
       "      <td>0.5</td>\n",
       "      <td>2.0</td>\n",
       "      <td>0.611976</td>\n",
       "      <td>0.572840</td>\n",
       "      <td>0.586869</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>False</td>\n",
       "      <td>4</td>\n",
       "      <td>0.5</td>\n",
       "      <td>5.0</td>\n",
       "      <td>0.612457</td>\n",
       "      <td>0.542646</td>\n",
       "      <td>0.588146</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>False</td>\n",
       "      <td>8</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.1</td>\n",
       "      <td>0.605458</td>\n",
       "      <td>0.570576</td>\n",
       "      <td>0.562856</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>False</td>\n",
       "      <td>8</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.611551</td>\n",
       "      <td>0.568605</td>\n",
       "      <td>0.567262</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>False</td>\n",
       "      <td>8</td>\n",
       "      <td>0.5</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.610274</td>\n",
       "      <td>0.563093</td>\n",
       "      <td>0.566433</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>False</td>\n",
       "      <td>8</td>\n",
       "      <td>0.5</td>\n",
       "      <td>2.0</td>\n",
       "      <td>0.616798</td>\n",
       "      <td>0.556067</td>\n",
       "      <td>0.572001</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>False</td>\n",
       "      <td>8</td>\n",
       "      <td>0.5</td>\n",
       "      <td>5.0</td>\n",
       "      <td>0.615927</td>\n",
       "      <td>0.526028</td>\n",
       "      <td>0.571735</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "    sampling  beams  gammas  deltas  baseline_coherence  watermark_coherence  \\\n",
       "0      False      1     0.5     0.1            0.614911             0.557207   \n",
       "1      False      1     0.5     0.5            0.613323             0.572616   \n",
       "2      False      1     0.5     1.0            0.613967             0.568145   \n",
       "3      False      1     0.5     2.0            0.613299             0.564281   \n",
       "4      False      1     0.5     5.0            0.616185             0.551181   \n",
       "5      False      4     0.5     0.1            0.613063             0.592225   \n",
       "6      False      4     0.5     0.5            0.610608             0.584787   \n",
       "7      False      4     0.5     1.0            0.608079             0.581858   \n",
       "8      False      4     0.5     2.0            0.611976             0.572840   \n",
       "9      False      4     0.5     5.0            0.612457             0.542646   \n",
       "10     False      8     0.5     0.1            0.605458             0.570576   \n",
       "11     False      8     0.5     0.5            0.611551             0.568605   \n",
       "12     False      8     0.5     1.0            0.610274             0.563093   \n",
       "13     False      8     0.5     2.0            0.616798             0.556067   \n",
       "14     False      8     0.5     5.0            0.615927             0.526028   \n",
       "\n",
       "    no_watermark_coherence  \n",
       "0                 0.565086  \n",
       "1                 0.566163  \n",
       "2                 0.561886  \n",
       "3                 0.563407  \n",
       "4                 0.566810  \n",
       "5                 0.591852  \n",
       "6                 0.587506  \n",
       "7                 0.579531  \n",
       "8                 0.586869  \n",
       "9                 0.588146  \n",
       "10                0.562856  \n",
       "11                0.567262  \n",
       "12                0.566433  \n",
       "13                0.572001  \n",
       "14                0.571735  "
      ]
     },
     "execution_count": 29,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Greedy\n",
    "group_list =(\n",
    "    (False, 1, 0.1, 0.5),\n",
    "    (False, 1, 0.5, 0.5),\n",
    "    (False, 1, 1.0, 0.5),\n",
    "    (False, 1, 2.0, 0.5),\n",
    "    (False, 1, 5.0, 0.5),\n",
    "\n",
    "    (False, 4, 0.1, 0.5),\n",
    "    (False, 4, 0.5, 0.5),\n",
    "    (False, 4, 1.0, 0.5),\n",
    "    (False, 4, 2.0, 0.5),\n",
    "    (False, 4, 5.0, 0.5),\n",
    "\n",
    "    (False, 8, 0.1, 0.5),\n",
    "    (False, 8, 0.5, 0.5),\n",
    "    (False, 8, 1.0, 0.5),\n",
    "    (False, 8, 2.0, 0.5),\n",
    "    (False, 8, 5.0, 0.5),\n",
    ")\n",
    "\n",
    "sampling, beams, gammas, deltas = [], [], [], []\n",
    "baseline_coherence = []\n",
    "watermark_coherence = []\n",
    "no_watermark_coherence = []\n",
    "\n",
    "for idx, group in enumerate(group_list):\n",
    "    group_df = grouped_df.get_group(group)\n",
    "\n",
    "    sampling.append(group[0])\n",
    "    beams.append(group[1])\n",
    "    deltas.append(group[2])\n",
    "    gammas.append(group[3])\n",
    "    ## get coherence scores\n",
    "    prefix_text = group_df[\"truncated_input\"].values.tolist()\n",
    "\n",
    "    baseline_completion = group_df[\"baseline_completion\"].values.tolist()\n",
    "    w_bl_output = group_df[\"w_bl_output\"].values.tolist()\n",
    "    no_bl_output = group_df[\"no_bl_output\"].values.tolist()\n",
    "\n",
    "    baseline_coherence.append(get_coherence_score(prefix_text, baseline_completion))\n",
    "    watermark_coherence.append(get_coherence_score(prefix_text, w_bl_output))\n",
    "    no_watermark_coherence.append(get_coherence_score(prefix_text, no_bl_output))\n",
    "\n",
    "viz_df_greedy = pd.DataFrame()\n",
    "\n",
    "\n",
    "viz_df_greedy[\"sampling\"] = sampling\n",
    "viz_df_greedy[\"beams\"] = beams\n",
    "viz_df_greedy[\"gammas\"] = gammas\n",
    "viz_df_greedy[\"deltas\"] = deltas\n",
    "\n",
    "viz_df_greedy['baseline_coherence'] = baseline_coherence\n",
    "viz_df_greedy['watermark_coherence'] = watermark_coherence\n",
    "viz_df_greedy['no_watermark_coherence'] = no_watermark_coherence\n",
    "\n",
    "viz_df_greedy\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:14 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n",
      "03/31/2023 15:34:15 - INFO - matplotlib.texmanager -   No LaTeX-compatible font found for the serif fontfamily in rcParams. Using default.\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1200x300 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "gammas = viz_df_greedy[\"gammas\"].values.tolist()\n",
    "deltas = viz_df_greedy[\"deltas\"].values.tolist()\n",
    "\n",
    "baseline_coherence = viz_df_greedy[\"baseline_coherence\"].values.tolist()\n",
    "watermark_coherence = viz_df_greedy[\"watermark_coherence\"].values.tolist()\n",
    "no_watermark_coherence = viz_df_greedy[\"no_watermark_coherence\"].values.tolist()\n",
    "\n",
    "fig, axs = plt.subplots(ncols=3, nrows=1, figsize=(12,3), sharey=True)\n",
    "slice_idx = len(baseline_coherence)//3\n",
    "\n",
    "\n",
    "plt.subplot(1, 3, 1)\n",
    "plt.plot(deltas[:slice_idx], baseline_coherence[:slice_idx], label=\"baseline\")\n",
    "plt.plot(deltas[:slice_idx], no_watermark_coherence[:slice_idx], label=\"no watermark\")\n",
    "plt.plot(deltas[:slice_idx], watermark_coherence[:slice_idx], label=\"watermark\")\n",
    "plt.xticks(deltas[:slice_idx])\n",
    "plt.xlim(0, 5.1)\n",
    "# reverse x axis\n",
    "# axs[0].invert_xaxis()\n",
    "plt.title(\"Number of beams = 1\")\n",
    "plt.xlabel(\"delta\")\n",
    "plt.ylabel(\"coherence\")\n",
    "\n",
    "plt.subplot(1, 3, 2)\n",
    "plt.plot(deltas[slice_idx:slice_idx*2], baseline_coherence[slice_idx:slice_idx*2], label=\"baseline\")\n",
    "plt.plot(deltas[slice_idx:slice_idx*2], no_watermark_coherence[slice_idx:slice_idx*2], label=\"no watermark\")\n",
    "plt.plot(deltas[slice_idx:slice_idx*2], watermark_coherence[slice_idx:slice_idx*2], label=\"watermark\")\n",
    "plt.xticks(deltas[slice_idx:slice_idx*2])\n",
    "plt.xlim(0, 5.1)\n",
    "plt.title(\"Number of beams = 4\")\n",
    "plt.xlabel(\"delta\")\n",
    "plt.ylabel(\"coherence\")\n",
    "\n",
    "plt.subplot(1, 3, 3)\n",
    "plt.plot(deltas[slice_idx*2:], baseline_coherence[slice_idx*2:], label=\"baseline\")\n",
    "plt.plot(deltas[slice_idx*2:], no_watermark_coherence[slice_idx*2:], label=\"no watermark\")\n",
    "plt.plot(deltas[slice_idx*2:], watermark_coherence[slice_idx*2:], label=\"watermark\")\n",
    "plt.xticks(deltas[slice_idx*2:])\n",
    "plt.xlim(0, 5.1)\n",
    "plt.title(\"Number of beams = 8\")\n",
    "plt.xlabel(\"delta\")\n",
    "plt.ylabel(\"coherence\")\n",
    "\n",
    "\n",
    "# legend to right of both charts\n",
    "plt.legend(bbox_to_anchor=(1.05, 1), loc='upper left', borderaxespad=0.)\n",
    "plt.tight_layout()\n",
    "plt.savefig(f\"{OUTPUT_DIR}/beams_coherence_score.png\")\n",
    "\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "watermarking-dev",
   "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.10.10"
  },
  "vscode": {
   "interpreter": {
    "hash": "0a3c400d5c70e043163c46602e00ff3a948562bdc78a022eac13a63666386981"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
