{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "f1b5c80f-8e14-430b-9881-b9beb1437936",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "\n",
    "from matplotlib import style\n",
    "plt.style.use('seaborn-v0_8')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "75cdea0d-37c2-4d7f-8382-b51774b2044c",
   "metadata": {},
   "outputs": [],
   "source": [
    "datasets_map = {\n",
    "    \"mbpp\": \"MBPP\",\n",
    "}\n",
    "\n",
    "methods_map = {\n",
    "    \"LttHB\": \"LTT-HB\",\n",
    "    \"Hoeffding\": \"LTT-Hoeff.\",\n",
    "    \"RcpsWSR\": \"RCPS\",\n",
    "    'DKW': \"DKW\", \n",
    "    'DKWBonferroni': \"DKW\", \n",
    "    'OrderStats': \"Order Stats\", \n",
    "    'OrderStatsBonferroni': \"Order Stats\", \n",
    "    'KS': \"QRC-KS\",\n",
    "    'BJ': \"QRC-BJ\",\n",
    "    'One-sided-BJ': \"QRC (1-BJ)\",\n",
    "    'Two-sided-BJ': \"QRC (2-BJ)\",\n",
    "}\n",
    "\n",
    "method_order = list(methods_map.keys())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "7634235f-1526-4105-acdf-318e50b67c22",
   "metadata": {},
   "outputs": [],
   "source": [
    "def run_exp(\n",
    "    dataset = \"red_team_chat\",\n",
    "    loss_fn = \"toxicity\",\n",
    "    measure = \"Mean\",\n",
    "    beta_lo = 0.0,\n",
    "    beta_hi = 1.0,\n",
    "    no_data = 1000,\n",
    "    grid_size = 100,\n",
    "    single_prompt = False,\n",
    "    prompt_ind = 0,\n",
    "    alpha = 0.05,\n",
    "    plt_title = None\n",
    "):\n",
    "    if measure == \"VaR-Int\" or measure == \"CVaR\":\n",
    "        exp_name = \"{}_{}_beta_lo_{}_beta_hi_{}_no_data_{}_grid_size_{}_full_results\".format(\n",
    "            dataset, \n",
    "            loss_fn, \n",
    "            beta_lo,\n",
    "            beta_hi,\n",
    "            no_data, \n",
    "            grid_size\n",
    "        )\n",
    "        root = \"../output/{}/{}.csv\".format(\n",
    "            dataset, \n",
    "            exp_name\n",
    "        )\n",
    "        bound_col = \"guaranteed_auc\"\n",
    "        emp_col = \"empirical_auc\"\n",
    "\n",
    "    elif measure == \"VaR\":\n",
    "        exp_name = \"{}_{}_var_beta_{}_no_data_{}\".format(\n",
    "            dataset, \n",
    "            loss_fn, \n",
    "            beta_lo,\n",
    "            no_data, \n",
    "        )\n",
    "        root = \"../output/{}/{}.csv\".format(\n",
    "            dataset, \n",
    "            exp_name\n",
    "        )\n",
    "        bound_col = \"quantile_alpha\"\n",
    "        emp_col = \"quantile_loss\"\n",
    "        \n",
    "    elif measure == \"Mean\":\n",
    "        exp_name = \"{}_{}_mean_no_data_{}_prompt_ind_{}_full_results\".format(\n",
    "            dataset, \n",
    "            loss_fn, \n",
    "            no_data, \n",
    "            prompt_ind\n",
    "        )\n",
    "        root = \"../output/{}/{}.csv\".format(\n",
    "            dataset, \n",
    "            exp_name\n",
    "        )\n",
    "        bound_col = \"alpha\"\n",
    "        emp_col = \"mean loss\"\n",
    "    else:\n",
    "        raise ValueError\n",
    "\n",
    "    print(\"Experiment:\", exp_name)\n",
    "\n",
    "    df = pd.read_csv(root)\n",
    "    methods = list(set(df[\"method\"].tolist()))\n",
    "\n",
    "    all_bounds = []\n",
    "    all_emps = []\n",
    "    labels = []\n",
    "\n",
    "    method_tuples = [(method_order.index(mtd), mtd) for mtd in methods]\n",
    "    methods = [t[1] for t in sorted(method_tuples)]\n",
    "\n",
    "    if single_prompt:\n",
    "        emp_mean_risk = None\n",
    "    \n",
    "    for mtd in methods:\n",
    "\n",
    "        print(measure, mtd)\n",
    "\n",
    "        if (measure == \"VaR\") and ((\"Ltt\" in mtd) or (\"KS\" in mtd) or (\"DKW\" in mtd)):\n",
    "            continue\n",
    "        elif (\n",
    "            (\"DKW\" in mtd) or \n",
    "            (\"KS\" in mtd) or\n",
    "            (\"BJ\" in mtd) or\n",
    "            (\"Rcps\" in mtd)\n",
    "        ):\n",
    "            continue\n",
    "        \n",
    "        mtd_df = df[df[\"method\"] == mtd]\n",
    "        bounds = mtd_df[bound_col].tolist()\n",
    "        emps = mtd_df[emp_col].tolist()\n",
    "\n",
    "        all_bounds.append(bounds)\n",
    "        all_emps.append(emps)\n",
    "        labels.append(methods_map[mtd])\n",
    "\n",
    "        if single_prompt:\n",
    "            emp_mean_risk = np.mean(emps)\n",
    "\n",
    "    pal = plt.rcParams['axes.prop_cycle'].by_key()['color']\n",
    "    plt.rcParams[\"figure.figsize\"] = [5,2]\n",
    "\n",
    "    if single_prompt:\n",
    "        \n",
    "        bplot = plt.boxplot(\n",
    "            all_emps[:1] + all_bounds,\n",
    "            labels= [\"Empirical\"] + labels,\n",
    "            patch_artist = True,\n",
    "            vert=False,\n",
    "            boxprops = dict(\n",
    "                facecolor = pal[0], \n",
    "            ),\n",
    "            medianprops = dict(\n",
    "                color = \"k\", \n",
    "            ),\n",
    "            flierprops = dict(\n",
    "                # markerfacecolor = pal[0], \n",
    "                # alpha=0.75\n",
    "            ),\n",
    "        )\n",
    "        bplot[\"boxes\"][0].set_facecolor(pal[2])\n",
    "    else:\n",
    "        plt.boxplot(\n",
    "            all_emps,\n",
    "            labels=labels,\n",
    "            patch_artist = True,\n",
    "            boxprops = dict(\n",
    "                facecolor = pal[2], \n",
    "                # alpha=0.5\n",
    "            ),\n",
    "            medianprops = dict(\n",
    "                color = \"k\", \n",
    "            ),\n",
    "            flierprops = dict(\n",
    "                markerfacecolor = pal[2], \n",
    "                alpha=0.75\n",
    "            ),\n",
    "        )\n",
    "\n",
    "        plt.boxplot(\n",
    "            all_bounds,\n",
    "            labels=labels,\n",
    "            patch_artist = True,\n",
    "            boxprops = dict(\n",
    "                facecolor = pal[0], \n",
    "            ),\n",
    "            medianprops = dict(\n",
    "                color = \"k\", \n",
    "            ),\n",
    "            flierprops = dict(\n",
    "                markerfacecolor = pal[0], \n",
    "                alpha=0.75\n",
    "            ),\n",
    "        )\n",
    "    plt.xticks([0.3, 0.35, 0.4, 0.45, 0.5, 0.55])\n",
    "    plt.xlim(0.30, 0.55)\n",
    "    plt.tick_params(axis='x',labelsize=14)\n",
    "    plt.tick_params(axis='y',labelsize=14)\n",
    "        \n",
    "    # plt.scatter([],[], color=pal[0], label=\"Bound\")\n",
    "    # if not single_prompt:\n",
    "    #     plt.scatter([],[], color=pal[2], label=\"Empirical\")\n",
    "    #     plt.legend(loc=\"upper center\", frameon=True)\n",
    "    # else:\n",
    "    #     plt.legend(loc=\"lower left\", frameon=True)\n",
    "    # plt.ylim(0.45, 0.65)\n",
    "\n",
    "    plt.xlabel(measure + r\" Risk ($\\downarrow$)\", fontsize=16)\n",
    "    if plt_title is None:\n",
    "        plt.title(datasets_map[dataset], fontsize=18)\n",
    "    else:\n",
    "        plt.title(plt_title, fontsize=18)\n",
    "    plt.savefig(\"../plots/{}/{}.png\".format(dataset, exp_name), bbox_inches=\"tight\", dpi=600)\n",
    "    plt.show()\n",
    "        \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "27fe952a-5bca-41cd-b37c-70ad1ae9cb0a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Experiment: mbpp_pass-10_mean_no_data_500_prompt_ind_0_full_results\n",
      "Mean LttHB\n",
      "Mean Hoeffding\n",
      "Mean KS\n",
      "Mean BJ\n"
     ]
    },
    {
     "data": {
      "image/png": "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iAYNGmDEiBF49uwZ1q9fj+3bt2PSpEk69aNQ5CMvjx+OumLedFfeOevY0R1NmzbDypXfY+vWnTA0/PeSbn5+Pn788Qc0bWqHjh3dS4xDWfy0aPEOHB2dyi3m4hgbG6JOnVpITs4U461shaw+81Oc/HyBf59VCIuKIhT34Kvy1LZtWwAo9goI0evOyMgI/v5L4Oc3CmPG+GLatJlwcGiFW7du4uefV+LEiWPYtOk3nZ9XQUTli0VFJZOWlgag4NsYUXU2YMAH2LTpN/j7z0f//u+Jy5s2tcOmTb9p/ZwKKytrGBoawsrKurxCpXJgbV3wullb83WrSlhUVCIvX77Ejh07AAAdO3bUczRE+jdgwAfo27d/mZ6oaWfXHDduxPA27SrGzq454uPjYWRkzuGPKqRKFRXR0dGYO3euxnVvvfWW2hMqK7PCt5Tm5+fj+fPnOHPmDJ4+fQoHBwcMHz5czxESVQ5GRkbo3PndMvVRmQuK9CR5mfvI+L8+MkrRlxT7Ly/16tXjJM0qpkoVFc+ePUNQUJDGda6urlWqqHj1ltKaNWuiWbNm8PHxwUcffQRzc97mSPQ6s7GpCzMzc1w5+qNkfUaWsi8zM3PY2FTewouqDgNBEAR9B0HSKDyznEqmaUY+FY85K52i8iaXxyIpKVGSfaSmpsDaunaptrWxqVvpfvac51rpKPOmt/3rbc9ERNWcrW2TSvdhTlQWfPYpERERSYJFBREREUmCRQURERFJgkUFERERSYJFBREREUmCRQURERFJgkUFERERSYJFBREREUmCRQURERFJgkUFERERSYJFBREREUmCRQURERFJgkUFERERSYJFBREREUmCRQURERFJgkUFERERSYJFBREREUmCRQURERFJgkUFERERSYJFBREREUmCRQURERFJgkUFERERSYJFBREREUmCRQURERFJgkUFERERSYJFBREREUmCRQURERFJgkUFERERSYJFBREREUmCRQURERFJgkUFERERSYJFBREREUnCWN8BENHrRS6PRVJSYpn6SE1NgbV1bWkCAmBjUxe2tk0k64+INGNRQUSSkctj0dmjA15kZ+s7FBXmZmY4F3qJhQVROatWRcXcuXMRFBSEU6dOwdbWVuvt7O3t4erqit9++60co/tXjx49AACnT5+ukP0RSSUpKREvsrOxsL0LmllYlqqPR+np+CbyIhY6u6CZZen6UOkvIx3fXL6IpKREFhVE5azMRYVcLoenp2exbRo3bswPSKJqpJmFJexr1ylbH5Zl74OIKpZkVyqaNm2KDz74QOM6Swm+bUhh5syZ+OSTT9CgQQOdtgsODoa5uXk5RUWkm8TERNStW1ffYZCEyvKaKhQKnD8fivj4p2jQoCE6dfKAkZGRxBESaUfSomLq1KlSdVcu6tevj/r16+u8XYsWLcohGiLdPXz4AJ06OeP8+UjY2TXXdzgkgbK8pocPH4S//3w8fvxIXNa0aTP4+y/BgAGav+QRlacKv6XU3t4eo0aNQnx8PGbNmgU3Nzc4Oztj/PjxiI2NBQDExMTg008/haurK5ydnTFt2jQ8f/5cpR+5XA57e3vMnTsXd+/exfjx4+Hi4gJnZ2eMGzcO169fV9v33LlzYW9vD7lcLi67cOEC7O3tsXr1aly+fBnjxo2Di4sL7O3t1WJ+VU5ODrZs2YLBgwfD2dkZzs7O6NevH5YuXYrU1FSx3fnz5zFv3jz07t1bbOft7Y3AwMAy55Oql7S0VOTn5yMtLbXkxlQllPY1PXz4IPz8RsHBoRWCg0/i/v1/EBx8Eg4OreDnNwqHDx8sp4iJiqaX51SkpqbC19cXcrkcXl5ecHNzQ0hICMaOHYvo6Gj4+PggKysLgwcPRuvWrXH8+HHMnDlTY1+xsbHw9fVFdnY2fH190aNHD1y4cAEjR47E1atXtY4pMjISo0ePhoGBAYYOHYp+/foV2z47OxtjxozB0qVLkZGRgcGDB8PHxwd2dnYIDAzEP//8I7bdsGEDLl68iDZt2mDEiBF4//33kZKSgoULF2LZsmVax0hEBBQMefj7z0evXn2wdetOuLi4wsLCAi4urti6dSd69eoDf/8FUCgU+g6VqhnJhj8eP36M1atXa1zXtm1bdO3aVfzvO3fu4KOPPsK8efPEZf7+/ti5cydGjBiBKVOmYMyYMQAAQRAwYcIEhISE4MaNG3B0dFTp++LFixg/fjxmzZolLhs0aBA+/vhjLFiwAIcOHdIq/nPnzuH//b//h8GDB2vVftWqVbh8+TIGDhyIpUuXqoxhpqenw9Dw33rN398fTZqozjrPy8vD+PHjsW3bNowePRqNGjXSar/FMTLis8x0ocxXVcqbMtaYmLt6idvQ0AAWFmbIyMhGfr6gtj4m5m6Fx6QtfeUMKD5vypwZGRnC2Fi7+M6f/xuPHz/Chg0BMDV99W3cEJ99Nht9+ngiIiIMXbp01dhHZVcV/z4rA33nS9KiYs2aNRrXjR49WqWoqFmzJmbMmKHSZsCAAdi5cydq166N0aNHi8sNDAzQr18/hISE4Pbt22pFhZWVFSZOnKiy7N1334W7uzvCwsJw/fp1tG7dusT4HR0dtS4o8vLyEBgYCEtLS8yfP19tUtSrE1NfLSgAwNjYGD4+Pjh37hwuXLgALy8vrfZdHCsrTiYtjaqUN4Wi4PkPEyb46TmS4qXn5ug7BJEylsqeM4UiG3Xq1NKqbUZGCgDAw6MjLCzUt/Hw6Ci207bPyqoq/X2ShEVFly5dsGnTJq3a2tnZqd1N8cYbbwAomL9gYGCgsk45ufLZs2dqfTk4OKBWLfU/GhcXF4SFheHWrVtaFRXatFG6f/8+MjMz4eHhAWtr6xLbZ2RkYPPmzTh58iRiY2ORlZWlsl7TcZVGWtoLKBT5kvRVHRgZGcLKyrxK5c3IyAwA8MsvmyCT2ZfQWnolXamIjr6DCRP8YGliWuGxFUUZi75yBhSfN2XOjIzMkJycqVV/Fha1AQChoRHo2NFVbX14eITYTts+K5uq+PdZGSjzpi96efiVhYWF2jLlt/3i1uXl5amtq1evnsZ9KG/PSk9P1yqmovrRRNmnNrem5uTkYPTo0bhx4wZatWqFDz74ALVr14axsTHi4uIQFBSEnBxpvtUpFPnIy+Mfn66qUt6Ub64tWrwDR0enCt+/sbEh6tSpheTkTI05q8xv/vrKGVB83pQ50+U87NjRHU2bNsPKld9j69adKsOt+fn5+PHHH9C0qR06dnSvMud2UarS3ye9Bk/UfPWuEKXExILfHtD2GRmvXh0pjpWVFQAgPj6+xLanTp3CjRs3MGTIECxZskRl3ZEjRxAUFKT1fomIgIIvWv7+S+DnNwpjxvhi2rSZcHBohVu3buLnn1fixIlj2LTpNz6vgipclS8qbt26hczMTLUhkIsXLwIoGB6RWvPmzWFhYYFr164hNTW12CEQ5W2ymp46qoyRSFtWVtYwNDSElVXJw25UNZT2NR0w4ANs2vQb/P3no3//98TlTZvaYdOm3/icCtKLKj+tNi0tDevXr1dZdvbsWYSFhUEmk+k0V0JbxsbGGDZsGNLT07FkyRK127bS09ORmVkwjqm8q+PSpUsqbcLDw7F7927JY6PXm51dc9y4EcMHX71GyvKaDhjwAS5cuIKgoCNYv34TgoKO4MKFSBYUpDcVckspAIwfPx41atSQanciFxcX7Ny5E1evXkW7du0QFxeHY8eOwczMDN9++63k+1OaPn06rl69igMHDuDq1at49913YWpqCrlcjrNnz2LHjh1wcHBA9+7d0bhxY2zcuBF3797FO++8gwcPHuCvv/5Cz549cfz48XKLkV5PfET366csr6mRkRE6d35XwmiISq9CbikFgDFjxpRLUdGkSRP4+/vj+++/x++//478/Hy4urpi1qxZ5XKVQqlGjRoICAjA9u3bcfDgQezevRuGhoZo1KgRfHx80LhxYwBArVq1sHXrVnz//feIiIhAeHg43n77bfzwww+oW7cuiwp6LT3K0G6CtMZt/28i9CMtJ1mXZyxEpBsDQRDU7wurApS/jurl5cWnUv6fombkk2Yl3clA6krKmVwei84eHfAiO1sP0RXN3MwM50Iv6e2nz3mu6Y45Kx1l3vS2f73tmYheO7a2TXAu9BKSkhLL1E9qagqsrWtLExQAG5u6eisoiKoTFhVEJClb2yb8ACeqpqr83R9ERERUOVTZKxW2tra4c+eOvsMgIiKi/8MrFURERCQJFhVEREQkCRYVREREJAkWFURERCQJFhVEREQkCRYVREREJAkWFURERCQJFhVEREQkCRYVREREJAkWFURERCQJFhVEREQkCRYVREREJAkWFURERCQJA0EQBH0HQURERFUfr1QQERGRJFhUEBERkSRYVBAREZEkWFQQERGRJFhUEBERkSRYVBAREZEkWFQQERGRJFhUEBERkSRYVBAREZEkWFQQERGRJIz1HUB1FxUVhdWrVyMyMhJ5eXmQyWT46KOP0K9fP622DwkJwf79+3Hr1i08f/4cubm5ePPNN9G+fXt88sknaN68ucbtzp49i19++QU3btyAgYEBHB0d8emnn8Ld3V3KwysX+siZvb19kf15eXlh2bJlpT6eilLWvL0qNTUVAwYMwLNnz9ClSxds2rRJY7vqfK69Spuc8VwD9u3bh3nz5hW5ftu2bXBzc5N8v/qkj5z16NEDcXFxGtu7urrit99+0/4A/g+LCj06f/48Pv74Y5iamqJ///6oVasWTpw4gc8++wxPnz7FuHHjSuzjzJkzuHr1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",
      "text/plain": [
       "<Figure size 500x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Experiment: mbpp_pass-10_mean_no_data_500_prompt_ind_2_full_results\n",
      "Mean LttHB\n",
      "Mean Hoeffding\n",
      "Mean KS\n",
      "Mean BJ\n"
     ]
    },
    {
     "data": {
      "image/png": "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Q4fi8uXLCA8PR1RUFDw8PFC3bl0kJyfj7t27uHz5MpYtW1amsR5//PEHgoKCMHXq1DdmZlGi0nA2zcrjda+FsbExJkyYUkG9oapI56Ti6dOnCA8PV7tOMStlZVetWjVs2LABa9aswf79+7F+/XqYmprCxcUFEyZMgLOzs0p5AwMDLFmyBJ07d8bWrVvx559/IicnB1ZWVmjSpAlmz54Nd3d3Pe0NEZVVZormVxqz/lc2S4s6urZFVFUYCC9f96cqLTU1m6OktSCVGqJWrRqMmxbe1Jjxp88rnzf1WCtvirjprX29tUxEVElYWzdCRMQFpKSofxqsJOnpabC0rPnaciXNuWBlVZsJBb1RmFQQEaEosSivD3h+66a3xVv99AcRERGJh0kFERERiYJJBREREYmCSQURERGJgkkFERERiYJJBREREYmCSQURERGJgkkFERERiYJJBREREYmCSQURERGJgkkFERERiYJJBREREYmCSQURERGJgkkFERERiYJJBREREYmCSQURERGJgkkFERERiYJJBREREYmCSQURERGJgkkFERERiYJJBREREYmCSQURERGJgkkFERERiYJJBREREYmCSQURERGJgkkFERERiYJJBREREYmCSQURERGJgkkFERERiYJJBREREYmCSQURERGJgkkFERERiUKq7w4QEZWH+PhHSElJ1qpOenoaLC1r6tymlVVtWFs30rk+UVXHpIKI3jjx8Y/g4eGM3NznFdquiYkpIiIuMLGgtxaTCiJ646SkJCM39zna9P4c5lbWGtXJSolH9IEf4dT7c5hpWOdlmSnxuHTgR6SkJDOpoLdWlUgq4uPj4enpiY4dOyI4OFi5fOTIkYiMjCyXNhs2bIhjx46VuL5bt25ISkrClStXSixja2uLpk2b4uDBg8plO3bswNy5c1XKGRgYwMzMDDKZDD4+PvDx8Sn7DhARzK2sYVmvuVZ1zHSoQ0RFqkRSURIvLy+4urqqLDty5Ahu3rwJLy8vNGzYULk8IyMDmZmZKssAICgoCObm5hg9erTKcnNz8/LrOAB3d3e0a9cOAFBQUIAnT57g6NGj+PLLL3Hnzh3Mnj27XNsnKg/JycmoXbu2vrtBLyntNZHL5Th7NgKJiU9Qr159tG/vAYlEUsE9pDdJlU4qvL29iy1LSEhQJhVubm6v3UZQUBAsLCzw6aef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",
      "text/plain": [
       "<Figure size 500x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "run_exp(\n",
    "    dataset = \"mbpp\",\n",
    "    loss_fn = \"pass-10\",\n",
    "    prompt_ind = 0,\n",
    "    measure = \"Mean\",\n",
    "    single_prompt = True,\n",
    "    no_data = 500,\n",
    "    plt_title = \"System Prompt, Zero Shot\"\n",
    ")\n",
    "\n",
    "run_exp(\n",
    "    dataset = \"mbpp\",\n",
    "    loss_fn = \"pass-10\",\n",
    "    prompt_ind = 2,\n",
    "    measure = \"Mean\",\n",
    "    single_prompt = True,\n",
    "    no_data = 500,\n",
    "    plt_title = \"System Prompt, K-Shot\"\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fe1e0ada-95f2-4897-9ccd-570e88b33f15",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1978e48a-31ff-43c2-b210-2f5670197f8e",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
