{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "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>dataset</th>\n",
       "      <th>model</th>\n",
       "      <th>model_id</th>\n",
       "      <th>lambda</th>\n",
       "      <th>loss</th>\n",
       "      <th>samples</th>\n",
       "      <th>combined</th>\n",
       "      <th>polarity</th>\n",
       "      <th>semantic</th>\n",
       "      <th>history</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>539</th>\n",
       "      <td>sst2</td>\n",
       "      <td>gte-base</td>\n",
       "      <td>Triplet(gte-base)(lambda=7.5)</td>\n",
       "      <td>7.50</td>\n",
       "      <td>TripletLoss</td>\n",
       "      <td>50</td>\n",
       "      <td>0.82</td>\n",
       "      <td>0.804</td>\n",
       "      <td>0.837</td>\n",
       "      <td>[{'combined': 0.82, 'polarity': 0.804, 'semant...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>540</th>\n",
       "      <td>sst2</td>\n",
       "      <td>gte-base</td>\n",
       "      <td>Triplet(gte-base)(lambda=5)</td>\n",
       "      <td>5.00</td>\n",
       "      <td>TripletLoss</td>\n",
       "      <td>50</td>\n",
       "      <td>0.82</td>\n",
       "      <td>0.804</td>\n",
       "      <td>0.837</td>\n",
       "      <td>[{'combined': 0.82, 'polarity': 0.804, 'semant...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>541</th>\n",
       "      <td>sst2</td>\n",
       "      <td>gte-base</td>\n",
       "      <td>Triplet(gte-base)(lambda=1)</td>\n",
       "      <td>1.00</td>\n",
       "      <td>TripletLoss</td>\n",
       "      <td>50</td>\n",
       "      <td>0.82</td>\n",
       "      <td>0.804</td>\n",
       "      <td>0.837</td>\n",
       "      <td>[{'semantic': 0.837, 'combined': 0.82, 'polari...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>542</th>\n",
       "      <td>sst2</td>\n",
       "      <td>gte-base</td>\n",
       "      <td>Triplet(gte-base)(lambda=0.1)</td>\n",
       "      <td>0.10</td>\n",
       "      <td>TripletLoss</td>\n",
       "      <td>50</td>\n",
       "      <td>0.82</td>\n",
       "      <td>0.804</td>\n",
       "      <td>0.837</td>\n",
       "      <td>[{'combined': 0.82, 'polarity': 0.804, 'semant...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>543</th>\n",
       "      <td>sst2</td>\n",
       "      <td>gte-base</td>\n",
       "      <td>Triplet(gte-base)(lambda=0.01)</td>\n",
       "      <td>0.01</td>\n",
       "      <td>TripletLoss</td>\n",
       "      <td>50</td>\n",
       "      <td>0.82</td>\n",
       "      <td>0.804</td>\n",
       "      <td>0.837</td>\n",
       "      <td>[{'combined': 0.82, 'polarity': 0.804, 'semant...</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "    dataset     model                        model_id  lambda         loss  \\\n",
       "539    sst2  gte-base   Triplet(gte-base)(lambda=7.5)    7.50  TripletLoss   \n",
       "540    sst2  gte-base     Triplet(gte-base)(lambda=5)    5.00  TripletLoss   \n",
       "541    sst2  gte-base     Triplet(gte-base)(lambda=1)    1.00  TripletLoss   \n",
       "542    sst2  gte-base   Triplet(gte-base)(lambda=0.1)    0.10  TripletLoss   \n",
       "543    sst2  gte-base  Triplet(gte-base)(lambda=0.01)    0.01  TripletLoss   \n",
       "\n",
       "     samples  combined  polarity  semantic  \\\n",
       "539       50      0.82     0.804     0.837   \n",
       "540       50      0.82     0.804     0.837   \n",
       "541       50      0.82     0.804     0.837   \n",
       "542       50      0.82     0.804     0.837   \n",
       "543       50      0.82     0.804     0.837   \n",
       "\n",
       "                                               history  \n",
       "539  [{'combined': 0.82, 'polarity': 0.804, 'semant...  \n",
       "540  [{'combined': 0.82, 'polarity': 0.804, 'semant...  \n",
       "541  [{'semantic': 0.837, 'combined': 0.82, 'polari...  \n",
       "542  [{'combined': 0.82, 'polarity': 0.804, 'semant...  \n",
       "543  [{'combined': 0.82, 'polarity': 0.804, 'semant...  "
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import pandas as pd\n",
    "\n",
    "df = pd.read_csv(\"data/50-to-100k.csv\", index_col=0)\n",
    "df.tail()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "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>dataset</th>\n",
       "      <th>model_id</th>\n",
       "      <th>samples</th>\n",
       "      <th>combined</th>\n",
       "      <th>polarity</th>\n",
       "      <th>semantic</th>\n",
       "      <th>history</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>539</th>\n",
       "      <td>sst2</td>\n",
       "      <td>Triplet(gte-base)(lambda=7.5)</td>\n",
       "      <td>50</td>\n",
       "      <td>0.82</td>\n",
       "      <td>80.4</td>\n",
       "      <td>83.7</td>\n",
       "      <td>[{'combined': 0.82, 'polarity': 0.804, 'semant...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>540</th>\n",
       "      <td>sst2</td>\n",
       "      <td>Triplet(gte-base)(lambda=5)</td>\n",
       "      <td>50</td>\n",
       "      <td>0.82</td>\n",
       "      <td>80.4</td>\n",
       "      <td>83.7</td>\n",
       "      <td>[{'combined': 0.82, 'polarity': 0.804, 'semant...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>541</th>\n",
       "      <td>sst2</td>\n",
       "      <td>Triplet(gte-base)(lambda=1)</td>\n",
       "      <td>50</td>\n",
       "      <td>0.82</td>\n",
       "      <td>80.4</td>\n",
       "      <td>83.7</td>\n",
       "      <td>[{'semantic': 0.837, 'combined': 0.82, 'polari...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>542</th>\n",
       "      <td>sst2</td>\n",
       "      <td>Triplet(gte-base)(lambda=0.1)</td>\n",
       "      <td>50</td>\n",
       "      <td>0.82</td>\n",
       "      <td>80.4</td>\n",
       "      <td>83.7</td>\n",
       "      <td>[{'combined': 0.82, 'polarity': 0.804, 'semant...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>543</th>\n",
       "      <td>sst2</td>\n",
       "      <td>Triplet(gte-base)(lambda=0.01)</td>\n",
       "      <td>50</td>\n",
       "      <td>0.82</td>\n",
       "      <td>80.4</td>\n",
       "      <td>83.7</td>\n",
       "      <td>[{'combined': 0.82, 'polarity': 0.804, 'semant...</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "    dataset                        model_id  samples  combined  polarity  \\\n",
       "539    sst2   Triplet(gte-base)(lambda=7.5)       50      0.82      80.4   \n",
       "540    sst2     Triplet(gte-base)(lambda=5)       50      0.82      80.4   \n",
       "541    sst2     Triplet(gte-base)(lambda=1)       50      0.82      80.4   \n",
       "542    sst2   Triplet(gte-base)(lambda=0.1)       50      0.82      80.4   \n",
       "543    sst2  Triplet(gte-base)(lambda=0.01)       50      0.82      80.4   \n",
       "\n",
       "     semantic                                            history  \n",
       "539      83.7  [{'combined': 0.82, 'polarity': 0.804, 'semant...  \n",
       "540      83.7  [{'combined': 0.82, 'polarity': 0.804, 'semant...  \n",
       "541      83.7  [{'semantic': 0.837, 'combined': 0.82, 'polari...  \n",
       "542      83.7  [{'combined': 0.82, 'polarity': 0.804, 'semant...  \n",
       "543      83.7  [{'combined': 0.82, 'polarity': 0.804, 'semant...  "
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# make sure only to use sst2 for this exp:\n",
    "df = df.drop([\"model\", \"loss\", \"lambda\"], axis=1)\n",
    "# multiply polarity and semantic by 100\n",
    "df[\"polarity\"] = df[\"polarity\"] * 100\n",
    "df[\"semantic\"] = df[\"semantic\"] * 100\n",
    "df.tail()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/0k/1bg63zt532nb9d86g5tk_6vh0000gn/T/ipykernel_41846/342262391.py:25: UserWarning: set_ticklabels() should only be used with a fixed number of ticks, i.e. after set_ticks() or using a FixedLocator.\n",
      "  ax1.set_xticklabels(ax1.get_xticklabels(), rotation=45)\n",
      "/var/folders/0k/1bg63zt532nb9d86g5tk_6vh0000gn/T/ipykernel_41846/342262391.py:34: UserWarning: set_ticklabels() should only be used with a fixed number of ticks, i.e. after set_ticks() or using a FixedLocator.\n",
      "  ax2.set_xticklabels(ax2.get_xticklabels(), rotation=45)\n",
      "/var/folders/0k/1bg63zt532nb9d86g5tk_6vh0000gn/T/ipykernel_41846/342262391.py:36: UserWarning: FigureCanvasPgf is non-interactive, and thus cannot be shown\n",
      "  plt.show()\n"
     ]
    }
   ],
   "source": [
    "import matplotlib\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import os\n",
    "import sys\n",
    "sys.path.append(\"../\")\n",
    "from util import sns_config, matplot_config, tex_config\n",
    "\n",
    "sns.set_style(\"whitegrid\", sns_config)\n",
    "matplotlib.rcParams.update(matplot_config)\n",
    "\n",
    "save_latex = True\n",
    "\n",
    "if save_latex:\n",
    "    matplotlib.use(\"pgf\")\n",
    "    matplotlib.rcParams.update(tex_config)\n",
    "\n",
    "fig, (ax1, ax2) = plt.subplots(ncols=2, sharey=False, figsize=(15, 4))\n",
    "\n",
    "sns.set(style=\"whitegrid\")\n",
    "sns.boxplot(x=\"samples\", y=\"polarity\", data=df, palette=\"Set3\", hue=\"samples\", ax=ax1, legend=None)\n",
    "ax1.set_ylabel(\"Polarity\")\n",
    "# set y-axis limits:\n",
    "ax1.set_ylim([20, 95])\n",
    "ax1.set_xticklabels(ax1.get_xticklabels(), rotation=45)\n",
    "ax1.set_xlabel(\"\")\n",
    "\n",
    "sns.set(style=\"whitegrid\")\n",
    "sns.boxplot(x=\"samples\", y=\"semantic\", data=df, palette=\"Set3\", hue=\"samples\", ax=ax2, legend=None)\n",
    "# no x label:\n",
    "ax2.set_xlabel(\"\")\n",
    "ax2.set_ylabel(\"Semantic Similarity\")\n",
    "ax2.set_ylim([20, 95])\n",
    "ax2.set_xticklabels(ax2.get_xticklabels(), rotation=45)\n",
    "\n",
    "plt.show()\n",
    "if save_latex:\n",
    "    os.makedirs(\"figures\", exist_ok=True)\n",
    "    fig.savefig(\"figures/sample_size_box.pgf\", format=\"pgf\", bbox_inches=\"tight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "50 & 75.7 & 7.5 & 63.0 & 81.5 & 75.1 & 16.6 & 46.6 & 85.5\\\\\n",
      "500 & 75.7 & 7.5 & 63.0 & 81.5 & 75.1 & 16.6 & 46.6 & 85.5\\\\\n",
      "2000 & 75.7 & 7.5 & 62.9 & 81.7 & 75.1 & 16.6 & 46.6 & 85.5\\\\\n",
      "5000 & 76.3 & 7.7 & 63.1 & 83.1 & 75.1 & 16.6 & 46.5 & 85.5\\\\\n",
      "10000 & 78.0 & 8.3 & 63.2 & 87.3 & 74.9 & 16.8 & 45.7 & 85.4\\\\\n",
      "20000 & 81.5 & 8.7 & 61.8 & 89.2 & 73.0 & 18.3 & 36.4 & 84.9\\\\\n",
      "50000 & 86.2 & 6.4 & 68.0 & 92.5 & 70.2 & 21.3 & 29.6 & 84.7\\\\\n",
      "100000 & 88.9 & 4.0 & 72.2 & 93.4 & 69.3 & 22.3 & 29.0 & 84.6\\\\\n"
     ]
    }
   ],
   "source": [
    "by_samples = df.groupby(\"samples\")\n",
    "by_samples = pd.DataFrame(by_samples[[\"polarity\", \"semantic\"]].agg(\n",
    "    [\"mean\", \"std\", \"min\", \"max\"]\n",
    "))\n",
    "by_samples = by_samples * 100\n",
    "by_samples = by_samples.round(1)\n",
    "by_samples\n",
    "\n",
    "# create latex table rows for each sample size in the form of\n",
    "# metric = mean underscore std\n",
    "\n",
    "def make_latex_row(row):\n",
    "    return f\"{row['mean']:.1f} & {row['std']:.1f} & {row['min']:.1f} & {row['max']:.1f}\"\n",
    "\n",
    "# print for each sample size:\n",
    "for i, sample_size in enumerate(by_samples.index.values):\n",
    "    table_row = []\n",
    "    for metric in [\"polarity\", \"semantic\"]:\n",
    "        metric_df = by_samples[metric]\n",
    "        latex_rows = metric_df.apply(make_latex_row, axis=1)\n",
    "        table_row.append(latex_rows.values[i])\n",
    "    table_row_str = f\"{sample_size} & \" + \" & \".join(table_row) + \"\\\\\\\\\"\n",
    "    print(table_row_str)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{tabular}{lrrrrrrrr}\n",
      "\\toprule\n",
      " & \\multicolumn{4}{r}{polarity} & \\multicolumn{4}{r}{semantic} \\\\\n",
      " & mean & std & min & max & mean & std & min & max \\\\\n",
      "samples &  &  &  &  &  &  &  &  \\\\\n",
      "\\midrule\n",
      "50 & 75.7 & 7.5 & 63.0 & 81.5 & 75.1 & 16.6 & 46.6 & 85.5 \\\\\n",
      "500 & 75.7 & 7.5 & 63.0 & 81.5 & 75.1 & 16.6 & 46.6 & 85.5 \\\\\n",
      "2000 & 75.7 & 7.5 & 62.9 & 81.7 & 75.1 & 16.6 & 46.6 & 85.5 \\\\\n",
      "5000 & 76.3 & 7.7 & 63.1 & 83.1 & 75.1 & 16.6 & 46.5 & 85.5 \\\\\n",
      "10000 & 78.0 & 8.3 & 63.2 & 87.3 & 74.9 & 16.8 & 45.7 & 85.4 \\\\\n",
      "20000 & 81.5 & 8.7 & 61.8 & 89.2 & 73.0 & 18.3 & 36.4 & 84.9 \\\\\n",
      "50000 & 86.2 & 6.4 & 68.0 & 92.5 & 70.2 & 21.3 & 29.6 & 84.7 \\\\\n",
      "100000 & 88.9 & 4.0 & 72.2 & 93.4 & 69.3 & 22.3 & 29.0 & 84.6 \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print(by_samples.to_latex(float_format=\"%.1f\"))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "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>polarity</th>\n",
       "      <th>semantic</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>samples</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>50</th>\n",
       "      <td>81.5</td>\n",
       "      <td>85.5</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>500</th>\n",
       "      <td>81.5</td>\n",
       "      <td>85.5</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2000</th>\n",
       "      <td>81.7</td>\n",
       "      <td>85.5</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5000</th>\n",
       "      <td>83.1</td>\n",
       "      <td>85.5</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10000</th>\n",
       "      <td>87.3</td>\n",
       "      <td>85.4</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20000</th>\n",
       "      <td>89.2</td>\n",
       "      <td>84.9</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>50000</th>\n",
       "      <td>92.5</td>\n",
       "      <td>84.7</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>100000</th>\n",
       "      <td>93.4</td>\n",
       "      <td>84.6</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "         polarity  semantic\n",
       "samples                    \n",
       "50           81.5      85.5\n",
       "500          81.5      85.5\n",
       "2000         81.7      85.5\n",
       "5000         83.1      85.5\n",
       "10000        87.3      85.4\n",
       "20000        89.2      84.9\n",
       "50000        92.5      84.7\n",
       "100000       93.4      84.6"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "max_df = by_samples.xs(\"max\", level=1, axis=1)\n",
    "max_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/0k/1bg63zt532nb9d86g5tk_6vh0000gn/T/ipykernel_41815/1116725819.py:45: UserWarning: FigureCanvasPgf is non-interactive, and thus cannot be shown\n",
      "  plt.show()\n"
     ]
    }
   ],
   "source": [
    "import seaborn as sns\n",
    "import os\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib\n",
    "import sys\n",
    "sys.path.append(\"../\")\n",
    "from util import sns_config, matplot_config, tex_config\n",
    "\n",
    "sns.set_style(\"whitegrid\", sns_config)\n",
    "matplotlib.rcParams.update(matplot_config)\n",
    "\n",
    "save_latex = True\n",
    "\n",
    "if save_latex:\n",
    "    matplotlib.use(\"pgf\")\n",
    "    matplotlib.rcParams.update(tex_config)\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(7, 4))\n",
    "# line styles for each metric\n",
    "line_styles = [\n",
    "    (5, 1),  # solid line\n",
    "    (3, 1),  # dashed line\n",
    "    (1, 1),  # dotted line\n",
    "]\n",
    "\n",
    "ax.set_xscale(\"log\")\n",
    "ticks = [str(x) for x in max_df.index]\n",
    "num_to_k = lambda x: x[:-3] + \"k\" if x.endswith(\"000\") else x\n",
    "ticks = [num_to_k(x) for x in ticks]\n",
    "ax.set_xlim([50, 100000])\n",
    "ax.set_xticks(max_df.index)\n",
    "ax.set_xticklabels(ticks)\n",
    "\n",
    "# rotate 45\n",
    "ax.tick_params(axis='x', rotation=45)\n",
    "\n",
    "agg = \"max\"  # min/max\n",
    "sns.lineplot(data=max_df, x=\"samples\", y=f\"polarity\", ax=ax, linestyle=\"dotted\", label=\"Polarity\")\n",
    "sns.lineplot(data=max_df, x=\"samples\", y=f\"semantic\", ax=ax, errorbar=\"sd\", linestyle=\"dashed\", label=\"Semantic Similarity\")\n",
    "ax.set_xlabel(\"Sample size\")\n",
    "ax.set_ylabel(\"Max Score\")\n",
    "\n",
    "ax.set_ylim([80, 100])\n",
    "plt.tight_layout()\n",
    "plt.show()\n",
    "if save_latex:\n",
    "    os.makedirs(\"figures\", exist_ok=True)\n",
    "    fig.savefig(\"figures/sample_size.pgf\", format=\"pgf\")"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "simcse",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.16"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
