{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import polars as pl\n",
    "import pandas as pd\n",
    "from scipy import stats\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import numpy as np\n",
    "import os\n",
    "import csv"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "base = 'results/separated'\n",
    "exp = 'apple-small-imdb'\n",
    "df = pl.read_parquet(f'{base}/{exp}.parquet')\n",
    "df = df.filter(pl.col(\"token_id\") != -100)\n",
    "outdir = f'iclr-plots/quadrant'\n",
    "os.makedirs(outdir, exist_ok=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "11 | [0.0, 0.1, 0.2, 0.4, 0.6, 0.8, 1.0, 1.25, 1.5, 1.75, 2.0]\n"
     ]
    }
   ],
   "source": [
    "wds = list(df['wd'].unique())\n",
    "print(f\"{len(wds)} | {[round(x, 2) for x in wds]}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# helper functions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "min_exp = 0  # e.g., starting from 3^0\n",
    "max_exp = 10  # e.g., ending at 3^10 (adjust as needed)\n",
    "bins = 3 ** np.arange(min_exp, max_exp)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_bin_range(bin_num):\n",
    "    exp_start = bin_num\n",
    "    exp_end = bin_num + 1\n",
    "    return fr\"$3^{{{exp_start}}} - 3^{{{exp_end}}}$\"\n",
    "\n",
    "def assign_bin(freq):\n",
    "    return np.digitize(freq, bins) - 1"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# create last iter df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "def filter_by_max_iter(df: pl.DataFrame) -> pl.DataFrame:\n",
    "    max_iter_by_group = df.group_by(['wd', 'seed']).agg(pl.col('iter').max().alias('max_iter'))\n",
    "    df_with_max = df.join(max_iter_by_group, on=['wd', 'seed'])\n",
    "    filtered_df = df_with_max.filter(pl.col('iter') == pl.col('max_iter'))\n",
    "    return filtered_df.drop('max_iter')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "df = filter_by_max_iter(df)\n",
    "df = df.with_columns([\n",
    "    pl.col('tok_freq').map_elements(assign_bin, return_dtype=pl.Int64).alias('bin')\n",
    "]).select(['wd', 'seed', 'loss', 'token_id', 'tok_loss', 'tok_acc', 'tok_freq', 'bin'])\\\n",
    ".sort(['wd', 'seed', 'tok_freq'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "bin2str = {b : get_bin_range(b) for b in df['bin'].unique()}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_pl = df.filter(pl.col('bin').is_in([0, 7])).sort('bin')\n",
    "df_pl = df_pl.sort(['wd', 'bin'])\n",
    "df_pl = df_pl.group_by(['wd', 'bin', 'token_id']).agg([\n",
    "    pl.col('tok_loss').mean().alias('mean_tok_loss'),\n",
    "]).sort(['wd', 'bin'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABBYAAAInCAYAAAAs1NqYAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAACc00lEQVR4nOzdaXgUVfr38V9lDwlpQCBsSVARFWGQTVFWWVxRcYERVDYZRo24oygiIkYdRx1RIhj/IsvAgIqAyCK4AAMIxgBuQQWBJIBE1mxkTz0vfNJjTAKdrkq6O/l+rosrpKrOOXfddELX3VXnGKZpmgIAAAAAAHCDn6cDAAAAAAAAvovCAgAAAAAAcBuFBQAAAAAA4DYKCwAAAAAAwG0UFgAAAAAAgNsoLAAAAAAAALdRWAAAAAAAAG6jsAAAAAAAANwW4OkAcGYlJSU6dOiQ6tevL8MwPB0OAAAAAKCWM01TWVlZatGihfz8Tn9PAoUFLxYfH6/4+HgVFBTol19+8XQ4AAAAAIA6Ji0tTa1atTrtMYZpmmYNxQM3ZWRkqEGDBkpLS1NERISnw6lUYWGh1q5dqyuvvFKBgYGeDqdWIKf2I6f2Ip/2I6f2Ip/2I6f2Ip/2I6f2Ip/285WcZmZmKioqSidPnpTD4Tjtsdyx4ANKH3+IiIjw+sJCvXr1FBER4dU/IL6EnNqPnNqLfNqPnNqLfNqPnNqLfNqPnNqLfNrP13LqyuP4TN4IAAAAAADcRmEBAAAAAAC4jcICAAAAAABwG4UFAAAAAADgNgoLAAAAAADAbRQWAAAAAACA2ygsAAAAAAAAtwV4OgBUL9M0VVhYqJKSkmofq7CwUAEBAcrLy1NxcXG1j1cX1IWc+vn5KTAw0KX1cQEAAAB4HwoLtVRBQYF+++03nTp1qsYuSE3TVLNmzZSWlsZFok3qSk79/f1Vr149NW3aVEFBQZ4OBwAAAEAVUFiohU6dOqW0tDT5+/urYcOGCg0Nlb+/f7VfmJaUlCg7O1vh4eHy8+MpGzvU9pyapqni4mLl5uYqIyND+/fvV6tWrVSvXj1PhwYAAADARRQWaqGjR48qMDBQMTEx8vf3r7FxS0pKVFBQoJCQkFp5EewJdSWn4eHhatSokVJSUnT06FFFR0d7OiQAAAAALqq9Vyp1VFFRkXJyctSoUaMaLSoAVvn7+6tRo0bKyclRUVGRp8MBAAAA4CIKC7VM6QVZcHCwhyMBqq70dUthAQAAAPAdFBZqqdo80R9qL163AAAAgO+hsAAAAAAAANxGYQEAAAAAALiNwgIAAAAAAHAbhYU6rnXr1jIM47R/XnvtNU+HCYsq+3cODw9Xx44d9cQTT+jYsWMVth01apQMw9CcOXNqNmgAAAAAPiHA0wHAO/To0UNt2rSpcF+7du1qOBpUlz/+O5eUlOjQoUPasmWLXnzxRc2bN0///e9/dc4553g4SgAAAAC+hMICJEljx47VqFGjPB0GqllF/86HDx9Wnz599PPPP+uxxx7TBx98UGb/Cy+8oIkTJ6p58+Y1GCkAAAAAX8GjEEAd16xZM02YMEGS9Nlnn5Xb37x5c11wwQVyOBw1HRoAAAAAH0BhoZrt2bNHd999tzp37qzAwEC1bt3a0yG5rfQ5/f3792v58uXq16+fGjVqJMMwtH79eudxJ06c0JQpU3TxxRerfv36qlevnjp06KDnnntOp06dqrDvoqIivfbaa+rQoYNCQkLUpEkT3XLLLfruu+80Z84cGYZR7pP2Z555RoZh6Jlnnqmwz/Xr18swDPXt27fC/YcOHdLDDz+sCy+8UPXq1VP9+vXVrVs3zZgxQ0VFReWO/+NcA/v27dOdd96pZs2aKTg4WOeee66eeuop5efnV5q/pKQkjRw5UmeffbZCQkLUqFEjdezYURMmTFBKSook6d1335VhGLrqqqsq7efQoUMKDAxUaGhopfMiVFWzZs0k6Yzn/Ud/zP+RI0cUGxurqKgoBQUFKSoqSuPHj9fJkydtiQ8AAACA96KwUM1++OEHffzxx2rdurXat2/v6XBs8corr2jw4MHKysrS1VdfrT59+sjf31+S9OOPP6pTp0569tln9dtvv6lnz54aMGCAjhw5osmTJ6tHjx7KyMgo019JSYmGDBmihx56SD///LP69Omj/v37a/v27brkkkuUmJho+zls3LhR7du317/+9S/l5eVp4MCB6tGjh3755ReNHz9e1113nQoLCytsu3PnTl188cX673//qz59+qh379769ddfFRcXp9tuu63CNv/85z91ySWXaN68eQoKCtKNN96onj17qrCwUC+//LK++OILSdLw4cPVpEkTrVu3Tj///HOFfb311lsqKirSsGHDdNZZZ9mSj6+++kqSdNFFF1W5bVpamjp37qwlS5bokksu0cCBA5WVlaUZM2boyiuvrDSPAAAAAGoHCgvV7Prrr9eBAwf04Ycf6tJLL/V0OLaYOXOmli9frsTERC1cuFDr169Xr169lJubq+HDhystLU1PPfWU9u/fr9WrV+ujjz7S3r17NWzYMO3cuVMPPfRQuf6WLVumyMhI7dy5U5988okWLVqk3bt3a/To0XrzzTdtjf/w4cO6+eabdfLkSb355pv65ZdftHz5cq1Zs0a7d+9Wv379tHbtWr3wwgsVtp8+fbrGjx+vX375RYsXL9a6dev01VdfKSwsTMuWLdOXX35Z5viPPvpIjz32mIKCgrR48WL99NNPWrx4sT766CMlJyfrhx9+cL42goODNW7cOJmmqfj4+HJjFxYWKiEhQZJ03333WcpDSUmJDh48qBkzZuill16Sv7+/nnrqqSr3M3v2bA0YMEApKSlasmSJVq5cqe+++04tW7ZUYmJiuTkbAAAAANQuFBaqmZ+fb6R49OjRFS5HWNFjBCNHjtQNN9xQbvvcuXO1b98+XXfddZo2bZqCgoKc++rVq6eEhAQ1bdpU8+fP14kTJ5z7SpezfOaZZ3ThhRc6twcEBOjVV1913qZvl9dee03Hjh1TbGys7rnnnjL/RmeddZbmzZunwMBAzZgxQ6ZplmvfpUsXTZs2zXmXhiS1b99ed955pyTp008/LXP8lClTJElxcXEaOnRouf7atWtX5rzvvfdeBQYGau7cucrJySlz7JIlS3T48GFddtll6ty5c5XP/Y//zv7+/mrVqpXGjx+vv/zlL9qwYYMGDRpU5T5btWql+Ph4BQcHO7eVPgohlc8HAAAAgNrFN656bfbTTz/pjTfe0KhRo9ShQwcFBATIMAw999xzLrV///331bdvXzVs2FBhYWHq2LGjXnrpJZ++5btHjx4aOXJkuT9XX311uWNvvfXWCvtYtWqVJFV48SxJ4eHh6tq1q4qKipyPNxw8eFB79uyRJN1xxx3l2oSEhFTan7tWrlwpSfrrX/9a4f6WLVvqvPPO05EjR7R79+5y+wcNGiTDMMptLy0OHDx40Lnt8OHD2rlzp/z8/HTXXXe5FF+LFi106623KiMjQ/Pnzy+zr/QuBnfvVvjzv/N1112nqKgoJSYm6qGHHqrwfM+kf//+qlevXrntFeUDAAAAQO1TJ5ebnDlzpqZPn+5W2wcffFDTp09XQECA+vXrp/DwcH3++ed6/PHHtWLFCq1du1ahoaE2R1z9qrLcZGUTUO7bt0+SnBetp3PkyBFJ0oEDByRJjRs3Vnh4eIXHnn322S7F5aq9e/dKknr16nXGY48cOaK2bduW2RYdHV3hsREREZKkvLw857bU1FRJv6+sUJVVFe6//3795z//0cyZMzV8+HBJ0rfffqtNmzYpMjKy0uLOmVT071xUVKSnn35aL7zwgvr06aOffvpJ9evXd7nPquQDAAAAQO1TJwsL7du316OPPqpOnTqpc+fOev7558t9MlyRZcuWafr06QoPD9eGDRuct6IfPXpU/fr106ZNmzR58mS9/PLL1X0KHlVZ4aSkpESSdNVVV53x8YWYmBjb46osnsq233rrrQoLCzttHxVNjlgTj7d0795dl1xyib766itt3rxZ11xzjfNuhXHjxpV5zMSqgIAAPffcc3r77bf166+/at68eYqNjXW5va887gMAAACgetTJwsLYsWPLfO/qhdHzzz8vSZo4cWKZ59sbN26sN998U7169dKMGTM0efLkKn06XVu0atVKP/74o8aMGePy4wstW7aU9HtxJjs7u8K7Fvbv319h29KL66ysrAr3ly7h+GdRUVHavXu3Hn/8cXXt2tWlON1V+mn+r7/+qoyMjCrftXDHHXfo7bff1mWXXaYFCxYoICBAd999t+1x+vn5qXXr1jp69Kh27dple/8AAAAAai8+anTRwYMHnfMClN6a/kc9e/ZUVFSU8vPznXMN1DXXXHONpN/noHBVq1atdM4550iSFi5cWG5/fn5+pf2VFiUquxAunUuhsjjfe+89l+N0V7NmzdSxY0eVlJRo9uzZVWo7dOhQNW/eXCtXrtTzzz+vnJwc3XTTTWrRooXtcZaUlDgLOJU9kgIAAAAAFamTdyy4Y8eOHZKkRo0aVfrMf9euXZWWlqYdO3Zo2LBhbo+Vn5+v/Px85/eZmZmSfl9q8EwTRBYWFso0TZWUlFT6KEBFqnJ8ZceOHTtWr732mj744AM99thjmjRpUrln9Q8fPqwVK1bob3/7m3PbAw88oAceeEDPPPOMevbsqQsuuECSVFxcrEceeUSHDh2SJOd5lerbt6/8/Pz0ySef6IsvvlCfPn2cx82YMUNLliwpE3OpRx55RPPmzdOrr76qpk2b6r777iv3aMG+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m5bZl5mZqcTEREVEROiSSy6p1nMCAAAAUPdUa2GhVGBgoEJDQ52zYpYuR2mapgoKCrRo0SJddtlluvHGG3XgwIGaCAnwuPXr10uSbrvtNgUHB5fbf/PNN6thw4bKyspSUlKSc3tpYeGPdyWU/v3KK69U//799eOPP+rgwYPOcYqKitSnT58yj04AAAAAgB2qtbCQnJysBx98UC1atNCoUaP05ZdfSvq9oNCnTx/FxcWpY8eOzrsYPv74Y11yySUUF/6/+Ph4tWvXTt26dfN0KKgGpRf+Z599doX7DcNw7is9VpIuu+wyhYWFadu2bcrOzpZpmvr888914YUXqmXLluUKDzwGAQAAAKA62V5YyM/P17x589SzZ0916NBBb7zxhk6cOCHTNBUREaHx48frhx9+0BdffKEnnnhCO3bs0ObNm9WvXz+Zpqn09HQ9++yzdoflk2JjY5WcnKzExERPhwIvEhgYqN69e6uwsFDr16/Xd999p/T0dA0cOFBS+UclKCwAAAAAqE623Rf9ww8/KCEhQf/+97918uRJSb/fmSBJnTp10j333KPhw4erXr165dpedtll+vTTT3X99ddr5cqV+uyzz+wKC/BaLVu2lCTt3bu30mP27dtX5thSAwYM0OrVq/Xpp586l7IpLRxER0frvPPO02effaaDBw9q165datGihdq1a1cdpwEAAACgjrN0x0JeXp7mzp2rHj166C9/+YtmzJjhvDshODhYI0aM0JdffqmkpCSNHTu2wqLCH91+++2SpLS0NCthAT6hb9++kqTFixeXmZyx1NKlS3XixAnVr19fXbp0KbPvj3clfPrppwoICHD2V7r/8OHDeu211yRJ/fv3r5ZzAAAAAABLhYUWLVpozJgx2rp1q3OehDZt2uif//ynDh48qDlz5ujSSy91ub+GDRtKkoqLi62EBfiEIUOGKDo6WocOHdLDDz+soqIi5759+/bpkUcekST97W9/c058WqpDhw5q2rSpkpOT9cUXX6h79+6qX7++c39p4WHGjBllvgcAAAAAu1l6FKL0kQd/f38NGjRI9957r/M5b3e0bNlSI0eOtBIS4DWmTZumWbNmVbr/zTff1AcffKCrr75aM2fO1KpVq9S9e3dlZWXp888/V15enq688ko9/vjj5doahqH+/fvrP//5j/Ly8sr93PXr109+fn7OOyEo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Z6tPnz6aOXOm/vrXv7rUfvHixbrnnnuUlZUlwzD09NNPKyDA5eF91p49e/Tyyy/rq6++0nfffaeWLVtq//79ng4LAAD8f772hjj37N4qCW1QrWOcjl/uSYobNYwLYXv52s+8LzjTnACuzgdQ2hd8T5Wu7EePHq3169dr/vz5ysjI0PDhw/Xcc89pxIgR6tGjh9q0aaMGDRpIkk6ePKk9e/Zo8+bNmjdvnpKTk2WapgzD0PDhw91+lMLX/PDDD/r44491ySWXyDRNnThxwtMhAQDgFbzlYsnX3hCXhDZQSVjjah/HXd7y71qbcCFsL1+cGM/buTongLfMBwD7VfmWgbfffluFhYVatGiRDMNQcnKyJk6ceMZ2pmlKkm699Va98847VY/UR11//fXORz7uvvturVmzxsMReRZvNoC6x66fe37mf1ebfo96y8USb4jt5S3/rrWJrxW/vJ0vTowHeLsqFxaCgoK0cOFC9ezZU88++6x+++03l9o1adJETz/9tGJjY6scpC9zd/WM2oo3G/aqTRcY3oKc2s+un3t+5n9Xm36PcrFUO/FpsP0ofgHwdm5PcnDvvfdqzJgxWrBggdasWaNNmzYpPT29zDFNmzZVr169dNVVV+n2229XaGio5YD/7KefftLatWuVlJSkpKQk7dq1S8XFxZo2bZqeeuqpM7Z///33FR8fr2+++UYFBQVq06aNbr/9dj300EMKDAy0Pd66jjeR9qpNFxjegpzaz66fe37mf1ebLtq4WKqd+DQYAOoeS7MnhoSE6K677tJdd90lSSouLtbx48dlmqYaNWpUI5Mzzpw5U9OnT3er7YMPPqjp06crICBA/fr1U3h4uD7//HM9/vjjWrFihdauXVstxZC6jDeR9qpNFxjeguKX/fi5txcXbQAAwNvYeuXv7++vJk2a2NnlGbVv316PPvqoOnXqpM6dO+v555/X/Pnzz9hu2bJlmj59usLDw7VhwwZ17txZknT06FH169dPmzZt0uTJk/Xyyy8728yZM0ejR48+Y9/vv/++br31VvdPCnARFxj24yIYAIDq4crjhikpKWW+VobHDQHv4vPrPY4dO7bM967OafD8889LkiZOnOgsKkhS48aN9eabb6pXr16aMWOGJk+eLIfDIUm66aab1L179zP23bJlS1fDBwAAqBK/vIw6PT58V1UeN4yLizvt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z549rQwPAAAAAAA8zNIdC0OGDNH8+fO1Y8cOzZ49W2PGjDljm3vuuUcnTpyQYRi6/fbbrQwPAIDtSuc48BQjP8uj4wMAAFSVpcLCoEGD1L17d23dulV333230tPTNX78+AqP3bFjh5566imtWbNGhmHommuu0SWXXGJleAAAbBe6b6OnQwAAAPAplgoLkrR48WJdeumlOnz4sJ566ilNmzatzMRZ3bp104EDB/Tbb79JkkzTVHR0tObMmWN1aAAAbJd7dm+VhDbw2Pj+J9MUcmiHx8YHAACoKsuFhaioKG3btk1//etftXXrVud6v4ZhSJK2b98u0zSdx1966aVasmSJGjf23FJeAABUpiS0gVcsNwkAAOArLE3eWCoqKkpbtmzR8uXLdfPNN+uss86SaZrOP+Hh4bruuuv03nvv6csvv1SLFi3sGBYAAAAAAHiY5TsW/uj666/X9ddfL0k6deqUTp48qfDwcEVERFR4fF5enkJCQuwMAQAAAAAA1CBLdyzMnTu30n316tVTixYtTltUGDRokJXhAQAAAACAh1kqLIwbN05r1qypcruCggLdeOON+uKLL6wMDwAAAAAAPMzSoxCFhYUaMmSIvvjiC3Xt2tWlNgUFBbr55pu1bt065wSPqFh8fLzi4+NVXFzs6VAAoM7wy8vw6PhGQbZHxwcAAKgqS4WFs846S8eOHdN1112nzZs3q02bNqc9vqioSEOGDNGqVaskSX379rUyfK0XGxur2NhYZWZmyuFweDocAKjVHA6HAoOCpb0bPB0KAACAT7FUWPj444/Vv39/HT16VFdddZW2bNmiyMjICo8tLi7WX//6V61YsUKS1KtXL3388cdWhgcAwDaRkZH69/x5yshw/46FlJQUxcXFadKkSYqJiXGrj7179+rFF190OwYAAICaZqmwcOmll+q9997T4MGDtX//fl177bXasGGDwsPDyxxXXFys4cOHa+nSpZKkyy+/XCtXrlRoaKiV4QGgTktPT7d8EfzHr+5ITU11u603ioyMrLRAXhUxMTFq27atW22Lioosjw8AAFCTLC83ee2112rWrFkaO3asdu7cqZtuukmrVq1SYGCgJKmkpEQjRozQ+++/L0m65JJLtGbNmnLFBwB1W15enm0XqdHR0bV+Kdv09HTdcecIFRbkW+4rLi7OhogAAABQV1kuLEjSmDFj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+Tvh/vvvr8az8bzSfP75z7Rp09zu89VXXzUlmYZhmL179zaHDBliNmvWzJRknn/++eaRI0dsPIOaZ2fOdu/e7WzfqFEj88orrzT/+te/mt26dXNuHzRokJmfn1+u7bvvvmtKMs8991xz5MiRFf759ttv7Thlj7L7NTplyhRTktmxY8dK83bo0CGbz6Jm2Z2zyvI0cuRI84orrnD+vO/fv79Mu7rwGl23bp0zv82aNTOvu+46c+jQoWb79u2d28eNG2eWlJRUqV9f/T1KYQHllF60hoeHm0lJSc7tR44cMTt06GBKMh955BGX+zt48KBZr149U5L51ltvObcXFRWZd9xxh7PYUNUfOl9id063bNli/v3vfzffeustMzEx0Zw1a1aduVgzTXvzWVhYaHbp0sV87733zLy8vDL7vv32W7N58+amJHP06NG2noO3sfs1+me333676e/vb95zzz114rVaHfkcMWKEKckcPHhwuTcVxcXF5pdffmlL7N7K7pzef//9piSzS5cu5rFjx8rsW7lypbMYXpvz+vbbb5uPPvqouWDBAnPXrl3mnXfeaekCZPv27aZhGKa/v7+5atUq5/acnByzf//+piTzlltusSt8j7AzZ3v27DH79etnrl692iwqKiqzb/369WZYWJgpyZw6dWq5tqUXbSNHjnT3VHyC3a/R0sLClClT7A3Ui9ids9Mp/T994MCB5fbVhdfoZ599Zt5yyy3mxo0by+1btGiR8wOquXPnutynL/8epbCAckor5c8991y5ff/9739NSWZwcLB58uRJl/qbMGGCKckcMGBAuX1ZWVmmw+EwJZlr1qyxHLu3sjunf1b6y7u2X6yVqu58/tH8+fOdnxAXFBRY7s9bVWdOP/zwQ1OSOWHChDrzWrU7n59++qkpyWzfvn2tfh2ejt05Lf1E6b333qtw/8CBA01J5quvvmopbl8ycuRISxcgpXfUjB07tty+/fv3m35+fqYkc9euXVZD9RpWc3Y606ZNc37i+2d14aKtIlbzXRcKC39WXa/R3Nxc5x1jixYtKre/rr5G/+iuu+6q8nseX/49yhwLKOPgwYNKTEyUJA0fPrzc/p49eyoqKkr5+flatWqVS30uXbq00v7Cw8N1ww03SJI+/PBDd8P2atWR07qspvPZqVMnSVJubq6OHj1quT9vVJ05PXr0qO6++26d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GSM8PT0FANG3b19RVFSkV157seDv72+0vZSUFKFUKgUAERISIsaNGyfatWsnAIgWLVqIn3766RnslWPZ+5iGhITIl/ZYqtVqveW7du16BnvmGPY6nnfu3BEqlUoAEL6+vmLSpEkmX/fu3XuGe/js2fs7akx9CSwIYf/juX//fuHq6ioAiC5duoixY8eK4OBgAUAAEIsWLXoGe+VY9jym58+fF02bNhUAhKurq+jfv78YO3as6NKlizymEyZMeKGD3tnZ2Xp/M7THw9fXV2/5zZs3ZZ24uDgBQISHhxttc9WqVQKAUCgUon///iImJka0atVKABCdOnV67n+P2vOYnTlzRgawOnfubPbvj678/HwBQKhUKtG7d28RExMjoqKiREBAgPzuBgYG6vXheWXv460NToaFhYnY2FgxatQo0aFDB3ncBgwYIAoLC5/xXtpXbfxcCyHEt99+KwAIpVIpfv31V7N9qC/f0dTUVLk/PXr0MPnzWzXo/aL+HmVggUxKTk4W/fr1E2q1WjRs2FAEBASIFStWiJKSEoOy1lxgZGVliaioKNGsWTPh4uIi/P39xZ///Gdx+/btWtyLusWex1T7i8zc68svv6zdHXIwexzP3Nxcq44lAIO7mi8ie//cm6pTHwILQtj/eP7www9i0qRJwsfHRzg7O4smTZqIYcOGiX379tXiXtQt9jymt2/fFgsWLBBBQUHCzc1NODk5iWbNmokhQ4aI5OTkWt4Tx8vIyKj27z5rLkAOHDgghg4dKry8vIRKpRIdOnQQH3zwgdG7l88bex4za9sC9P9dLykpEYsWLRKRkZGibdu2wsPDQ353Bw0aJOLj443+PDyP7Hm88/LyxIIFC8TAgQNF69athZubm3B2dhatWrUSI0aMEJs3bxbl5eXPdgdrQW39XL/99tsCgBg2bJjFPtSX76j2b4ylV9W/QS/q71GFEDoPyCYiIiIiIiIiqgYmbyQiIiIiIiIimzGwQEREREREREQ2Y2CBiIiIiIiIiGzGwAIRERERERER2YyBBSIiIiIiIiKyGQMLRERERERERGQzBhaIiIiIiIiIyGYMLBARERERERGRzRhYICIiIiIiIiKbMbBARERERERERDZjYIGIiIiI6pSVK1dCoVDAxcUFbdu2xbx58/Dw4UNHd4uIiExgYIGIiOgFcvXqVSgUCigUCkyePLnW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",
      "text/plain": [
       "<Figure size 1200x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# ... existing code ...\n",
    "fig, ax = plt.subplots(figsize=(12, 6))\n",
    "\n",
    "sns.boxplot(data=df_pl, x='wd', y='mean_tok_loss', hue='bin', palette=['#1f77b4', '#ff7f0e'], ax=ax, showfliers=False)\n",
    "ax.grid(True, axis='y')\n",
    "ax.set_xlabel('Weight Decay $\\lambda$', fontsize=22)\n",
    "ax.set_ylabel('Per-Token Cross Entropy', fontsize=22)\n",
    "\n",
    "# Update this line\n",
    "handles, _ = ax.get_legend_handles_labels()\n",
    "ax.legend(handles, ['Low', 'High'], title='Frequency Bin', fontsize=16, title_fontsize=16)\n",
    "\n",
    "# log scale on y axis\n",
    "ax.set_yscale('log')\n",
    "# add ylimit from 10-2 to 10^1\n",
    "#ax.set_ylim(10**-2, 2*10**1)\n",
    "ax.set_ylim(2*10**-3, 2*10**1)\n",
    "plt.grid(True)\n",
    "\n",
    "# Increase font size of ticks to 16\n",
    "ax.tick_params(axis='both', which='major', labelsize=16)\n",
    "\n",
    "plt.savefig(f\"{outdir}/{exp}.pdf\", bbox_inches='tight', pad_inches=0.1)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "llm-wd-fairness-eaiv",
   "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.14"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
