{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "046da3c3-6d8f-419d-9569-bb1cae5c2cf0",
   "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": 85,
   "id": "342c5579",
   "metadata": {},
   "outputs": [],
   "source": [
    "base = 'results/separated'\n",
    "exp = 'apple-large-imdb-large'\n",
    "df = pl.read_parquet(f'{base}/{exp}.parquet')\n",
    "df = df.filter(pl.col(\"token_id\") != -100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 86,
   "id": "c5bd1d0a",
   "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",
   "id": "9df77e02",
   "metadata": {},
   "source": [
    "# helper functions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 87,
   "id": "b6f49286",
   "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": 88,
   "id": "8d3a70e1",
   "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": "code",
   "execution_count": 89,
   "id": "460461f6",
   "metadata": {},
   "outputs": [],
   "source": [
    "def calculate_learning_speed(losses):\n",
    "    # learning speed is inverse of AUC\n",
    "    # faster learning = smaller area\n",
    "    losses = np.array(losses, dtype=np.float32)\n",
    "    min_loss = losses.min()\n",
    "    range_losses = np.ptp(losses)\n",
    "    if range_losses == 0: return 0\n",
    "    normalized_losses = (losses - min_loss) / range_losses\n",
    "    auc = np.trapz(normalized_losses, dx=1)\n",
    "    return 1 - (auc / len(losses))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "97a6b200",
   "metadata": {},
   "source": [
    "# create last iter df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 90,
   "id": "89e21cfa",
   "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": 91,
   "id": "b64e4728",
   "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": 92,
   "id": "53e8a17a",
   "metadata": {},
   "outputs": [],
   "source": [
    "bin2str = {b : get_bin_range(b) for b in df['bin'].unique()}"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "379bcd0c",
   "metadata": {},
   "source": [
    "# loss scatter plots"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 93,
   "id": "b021883f",
   "metadata": {},
   "outputs": [],
   "source": [
    "def impair_scatterplot_loss(df, wd, save=True, outdir=None):\n",
    "    if save and outdir is None:\n",
    "        raise ValueError(\"Need output file.\")\n",
    "\n",
    "    # filter correct weight decay value.\n",
    "    tmp = df.filter(pl.col('wd') == wd)\n",
    "    tmp = tmp.group_by(['wd', 'token_id']).agg([\n",
    "        pl.col('tok_freq').mean(),\n",
    "        pl.col('tok_loss').mean(),\n",
    "        pl.col('tok_acc').mean(),\n",
    "        pl.col('tok_loss').mean().map_elements(lambda x: np.exp(x), return_dtype=pl.Float64).alias('tok_ppl'),\n",
    "        pl.col('bin').map_elements(lambda x: max(set(list(x)), key=list(x).count), return_dtype=pl.Int64).alias('bin'),\n",
    "        pl.col('bin').map_elements(lambda x: max(set(list(x)), key=list(x).count), return_dtype=pl.Int64).alias('bin').map_elements(lambda b: bin2str[b], return_dtype=pl.Utf8).alias('bin_str')\n",
    "    ]).sort(['tok_freq'])\n",
    "    \n",
    "    # produce the plot.\n",
    "    plt.figure(figsize=(10, 4))\n",
    "    sns.scatterplot(data=tmp, x='tok_freq', y='tok_loss', hue='bin_str', alpha=0.5)\n",
    "    plt.xscale('log')\n",
    "    plt.yscale('symlog')\n",
    "    plt.ylim(-0.1, 20)\n",
    "    plt.xlabel('Token Frequency', fontsize=17)\n",
    "    plt.ylabel('Per-Token Cross Entropy', fontsize=17)\n",
    "    plt.legend(title='Frequency Bins')\n",
    "    plt.tick_params(axis='x', which='both', length=0)\n",
    "    plt.grid(True)\n",
    "\n",
    "    # save to disk.\n",
    "    if save:\n",
    "        wdstr = str(round(wd*100)).zfill(3)\n",
    "        plt.savefig(f\"{outdir}/wd{wdstr}-per-token-loss.pdf\", bbox_inches='tight', pad_inches=0.1)\n",
    "        #plt.savefig(f\"{outdir}/wd{wdstr}-per-token-loss.png\", bbox_inches='tight', pad_inches=0.1, dpi=300)\n",
    "\n",
    "    plt.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 94,
   "id": "cf530ffa",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "generate plot for wd=2.0 (11/11)                                                                    \r"
     ]
    }
   ],
   "source": [
    "for i, wd in enumerate(wds):\n",
    "    outdir = f'iclr-plots/impair-loss/{exp}'\n",
    "    os.makedirs(outdir, exist_ok=True)\n",
    "    impair_scatterplot_loss(df, wd, save=True, outdir=outdir)\n",
    "    print(f\"generate plot for wd={round(wd, 2)} ({i+1}/{len(wds)})\".ljust(100), end='\\r')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2833e828",
   "metadata": {},
   "source": [
    "# accuracy scatter plots"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 95,
   "id": "eab14a73",
   "metadata": {},
   "outputs": [],
   "source": [
    "def impair_scatterplot_acc(df, wd, save=True, outdir=None):\n",
    "    if save and outdir is None:\n",
    "        raise ValueError(\"Need output file.\")\n",
    "\n",
    "    # filter correct weight decay value.\n",
    "    tmp = df.filter(pl.col('wd') == wd)\n",
    "    tmp = tmp.group_by(['wd', 'token_id']).agg([\n",
    "        pl.col('tok_freq').mean(),\n",
    "        pl.col('tok_loss').mean(),\n",
    "        pl.col('tok_acc').mean(),\n",
    "        pl.col('tok_loss').mean().map_elements(lambda x: np.exp(x), return_dtype=pl.Float64).alias('tok_ppl'),\n",
    "        pl.col('bin').map_elements(lambda x: max(set(list(x)), key=list(x).count), return_dtype=pl.Int64).alias('bin'),\n",
    "        pl.col('bin').map_elements(lambda x: max(set(list(x)), key=list(x).count), return_dtype=pl.Int64).alias('bin').map_elements(lambda b: bin2str[b], return_dtype=pl.Utf8).alias('bin_str')\n",
    "    ]).sort(['tok_freq'])\n",
    "    \n",
    "    # produce the plot.\n",
    "    plt.figure(figsize=(10, 4))\n",
    "    sns.scatterplot(data=tmp, x='tok_freq', y='tok_acc', hue='bin_str', alpha=0.5)\n",
    "    plt.xscale('log')\n",
    "    plt.xlabel('Token Frequency', fontsize=17)\n",
    "    plt.ylabel('Per-Token Accuracy (%)', fontsize=17)\n",
    "    plt.legend(title='Frequency Bins')\n",
    "    plt.grid(True)\n",
    "    plt.tick_params(axis='x', which='both', length=0)\n",
    "\n",
    "    # save to disk.\n",
    "    if save:\n",
    "        wdstr = str(round(wd*100)).zfill(3)\n",
    "        plt.savefig(f\"{outdir}/wd{wdstr}-per-token-loss.pdf\", bbox_inches='tight', pad_inches=0.1)\n",
    "        #plt.savefig(f\"{outdir}/wd{wdstr}-per-token-loss.png\", bbox_inches='tight', pad_inches=0.1, dpi=300)\n",
    "\n",
    "    plt.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 96,
   "id": "0475416e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "generate plot for wd=2.0 (11/11)                                                                    \r"
     ]
    }
   ],
   "source": [
    "for i, wd in enumerate(wds):\n",
    "    outdir = f'iclr-plots/impair-acc/{exp}'\n",
    "    os.makedirs(outdir, exist_ok=True)\n",
    "    impair_scatterplot_acc(df, wd, save=True, outdir=outdir)\n",
    "    print(f\"generate plot for wd={round(wd, 2)} ({i+1}/{len(wds)})\".ljust(100), end='\\r')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4e75bb5d",
   "metadata": {},
   "source": [
    "# impairment box plot"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 100,
   "id": "73ad0d2e",
   "metadata": {},
   "outputs": [],
   "source": [
    "def impair_boxplot_comp(df, wds, save=True, outdir=None):\n",
    "    if save and outdir is None:\n",
    "        raise ValueError(\"Need output file.\")\n",
    "\n",
    "    # prepare the dataframe.\n",
    "    df_pl = df.filter(pl.col('wd').is_in(wds)).sort('bin')\n",
    "    df_pl = df_pl.group_by(['wd', 'token_id']).agg([\n",
    "        pl.col('tok_freq').mean(),\n",
    "        pl.col('tok_loss').mean(),\n",
    "        pl.col('tok_acc').mean(),\n",
    "        pl.col('tok_loss').mean().map_elements(lambda x: np.exp(x), return_dtype=pl.Float64).alias('tok_ppl'),\n",
    "        pl.col('bin').map_elements(lambda x: max(set(list(x)), key=list(x).count), return_dtype=pl.Int64).alias('bin'),\n",
    "        pl.col('bin').map_elements(lambda x: max(set(list(x)), key=list(x).count), return_dtype=pl.Int64).alias('bin').map_elements(lambda b: bin2str[b], return_dtype=pl.Utf8).alias('bin_str')\n",
    "    ]).sort(['tok_freq'])\n",
    "\n",
    "    # helpers for plot.\n",
    "    bin_counts = df_pl.group_by('bin').len().sort('bin')\n",
    "    total_tokens = bin_counts['len'].sum()\n",
    "    bin_proportions = (bin_counts['len'] / total_tokens * 100)\n",
    "\n",
    "    # produce the plot.\n",
    "    fig, ax = plt.subplots(figsize=(10, 4))\n",
    "\n",
    "    sns.boxplot(data=df_pl, x='bin', y='tok_loss', showfliers=False, hue='wd', palette=['#1f77b4', '#ff7f0e'], ax=ax)\n",
    "    ax.grid(True)\n",
    "    ax.set_xlabel('', fontsize=17)\n",
    "    ax.set_ylabel('Token Cross Entropy', fontsize=17)\n",
    "    ax.legend(title='Weight Decay')\n",
    "\n",
    "    bins = df_pl['bin'].unique()\n",
    "    ax.set_xticks(range(len(bins)))\n",
    "    ax.set_xticklabels([])\n",
    "\n",
    "    ax2 = ax.twiny()\n",
    "    ax2.set_xlim(ax.get_xlim())\n",
    "    ax2.set_xlabel('Percentage of Tokens per Bin', fontsize=17)\n",
    "    ax2.set_xticks(range(len(bins)))\n",
    "\n",
    "    bin_proportions_labels = [f'{p:.2f}%' for p in bin_proportions]\n",
    "    ax2.set_xticklabels(bin_proportions_labels)\n",
    "\n",
    "    #ax.text(1.0, ax.get_ylim()[0] +1 , 'Low-frequency', ha='center', va='top', fontsize=17, bbox=dict(facecolor='white', alpha=0.5))\n",
    "    #ax.text(len(bins) - 2.0, ax.get_ylim()[0] +1, 'High-frequency', ha='center', va='top', fontsize=16, bbox=dict(facecolor='white', alpha=0.5))\n",
    "\n",
    "    # log plot on y axis.\n",
    "    ax.set_yscale('log')\n",
    "    #ax.set_ylim(0.01, 20)\n",
    "\n",
    "    # save to disk.\n",
    "    if save:\n",
    "        wdstr_left = str(round(wds[0]*100)).zfill(3)\n",
    "        wdstr_right = str(round(wds[1]*100)).zfill(3)\n",
    "        plt.savefig(f\"{outdir}/token-loss-wd-{wdstr_left}-vs-{wdstr_right}.pdf\", bbox_inches='tight', pad_inches=0.1)\n",
    "        #plt.savefig(f\"{outdir}/token-loss-wd-{wdstr_left}-vs-{wdstr_right}.png\", bbox_inches='tight', pad_inches=0.1, dpi=300)\n",
    "\n",
    "    if abs(wds[0] - 0.1) < 1e-6 and abs(wds[1] - 1.0) < 1e-6:\n",
    "        plt.show()\n",
    "    \n",
    "    plt.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 101,
   "id": "a80deb45",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "generate plot for wd=0.0 vs wd=2.0                                                                  \r"
     ]
    }
   ],
   "source": [
    "ref = wds[0]\n",
    "for i, wd in enumerate(wds):\n",
    "    if wd <= ref: continue\n",
    "    outdir = f'iclr-plots/impair-comp/{exp}'\n",
    "    os.makedirs(outdir, exist_ok=True)\n",
    "    impair_boxplot_comp(df, [ref, wd], save=True, outdir=outdir)\n",
    "    print(f\"generate plot for wd={round(ref, 2)} vs wd={round(wd, 2)}\".ljust(100), end='\\r')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 102,
   "id": "9ce0b788",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "generate plot for wd=0.1 vs wd=0.8                                                                  \r"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1000x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "generate plot for wd=0.1 vs wd=2.0                                                                  \r"
     ]
    }
   ],
   "source": [
    "ref = wds[1]\n",
    "for i, wd in enumerate(wds):\n",
    "    if wd <= ref: continue\n",
    "    outdir = f'iclr-plots/impair-comp/{exp}'\n",
    "    os.makedirs(outdir, exist_ok=True)\n",
    "    impair_boxplot_comp(df, [ref, wd], save=True, outdir=outdir)\n",
    "    print(f\"generate plot for wd={round(ref, 2)} vs wd={round(wd, 2)}\".ljust(100), end='\\r')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5e6ed694",
   "metadata": {},
   "source": [
    "# cross rebalanced loss"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "f384f79a",
   "metadata": {},
   "outputs": [],
   "source": [
    "# TODO: Add the test loss for Apple 270M."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "id": "2951f5a1",
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_rebalanced_loss(df, save=True, outdir=None):\n",
    "    if save and outdir is None:\n",
    "        raise ValueError(\"Need output file.\")\n",
    "\n",
    "    # prepare the dataframe.\n",
    "    df_last_loss = df.group_by(['wd', 'seed']).agg([\n",
    "        pl.col('loss').mean().alias('loss_avg'),\n",
    "    ]).sort(['wd', 'seed']).group_by(['wd']).agg(\n",
    "        pl.col('loss_avg').mean().alias('loss_seed_avg'),\n",
    "        pl.col('loss_avg').std().alias('loss_seed_std')\n",
    "    ).sort(['wd'])\n",
    "\n",
    "    df_last_tok_loss = df.group_by(['wd', 'seed']).agg([\n",
    "        pl.col('tok_loss').mean().alias('tok_loss_avg'),\n",
    "    ]).sort(['wd', 'seed']).group_by(['wd']).agg([\n",
    "        pl.col('tok_loss_avg').mean().alias('tok_loss_seed_avg'),\n",
    "        pl.col('tok_loss_avg').std().alias('tok_loss_seed_std'),\n",
    "    ]).sort(['wd'])\n",
    "\n",
    "    # produce the plot.\n",
    "    plt.figure(figsize=(10, 4))\n",
    "    plt.errorbar(\n",
    "        df_last_loss['wd'], \n",
    "        df_last_loss['loss_seed_avg'], \n",
    "        yerr=df_last_loss['loss_seed_std'], \n",
    "        fmt='-o', capsize=5, elinewidth=2, label='Average Train Loss'\n",
    "    )\n",
    "    plt.errorbar(\n",
    "        df_last_tok_loss['wd'], \n",
    "        df_last_tok_loss['tok_loss_seed_avg'], \n",
    "        yerr=df_last_tok_loss['tok_loss_seed_std'], \n",
    "        fmt='-o', capsize=5, elinewidth=2, label='Token-Balanced Loss'\n",
    "    )\n",
    "    plt.xlabel('Weight Decay', fontsize=17)\n",
    "    plt.ylabel('Cross Entropy', fontsize=17)\n",
    "    plt.grid(True)\n",
    "    plt.legend()\n",
    "    \n",
    "    # save to disk.\n",
    "    if save:\n",
    "        plt.savefig(f\"{outdir}/loss-vs-rebalanced-train.pdf\", bbox_inches='tight', pad_inches=0.1)\n",
    "        # plt.savefig(f\"{outdir}/loss-vs-rebalanced-train.png\", bbox_inches='tight', pad_inches=0.1, dpi=300)\n",
    "    \n",
    "    plt.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "id": "ee63dfa7",
   "metadata": {},
   "outputs": [],
   "source": [
    "outdir = f\"iclr-plots/rebalanced/{exp}\"\n",
    "os.makedirs(outdir, exist_ok=True)\n",
    "plot_rebalanced_loss(df, save=True, outdir=outdir)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7da6d57d",
   "metadata": {},
   "source": [
    "# add speed plots :)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "id": "fa987c8e",
   "metadata": {},
   "outputs": [],
   "source": [
    "base = 'results/learning-speed'\n",
    "df_speed = pl.read_parquet(f'{base}/{exp}.parquet')\n",
    "df_speed = df_speed.filter(pl.col(\"token_id\") != -100)\n",
    "df_speed = df_speed.group_by(['wd', 'token_id']).agg([\n",
    "    pl.col('avg_freq').mean().alias('tok_freq'),\n",
    "    pl.col('speed').mean().alias('tok_speed'),\n",
    "]).with_columns([\n",
    "    pl.col('tok_freq').map_elements(assign_bin, return_dtype=pl.Int64).alias('bin'),\n",
    "    pl.col('tok_freq').map_elements(assign_bin, return_dtype=pl.Int64).alias('bin').map_elements(lambda b: bin2str[b], return_dtype=pl.Utf8).alias('bin_str'),\n",
    "]).sort(['wd', 'bin'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 82,
   "id": "c2752d7a",
   "metadata": {},
   "outputs": [],
   "source": [
    "def impair_speed_plot(df, wds, save=True, outdir=None):\n",
    "    if save and outdir is None:\n",
    "        raise ValueError(\"Need output file.\")\n",
    "\n",
    "    # prepare the dataframe.\n",
    "    df_speed_pl = df_speed.filter(pl.col('wd').is_in(wds)).sort('bin')\n",
    "\n",
    "    # helpers for plot.\n",
    "    bin_counts = df_speed_pl.group_by('bin').len().sort('bin')\n",
    "    total_tokens = bin_counts['len'].sum()\n",
    "    bin_proportions = (bin_counts['len'] / total_tokens * 100)\n",
    "\n",
    "    # produce the plot.\n",
    "    fig, ax = plt.subplots(figsize=(10, 4))\n",
    "\n",
    "    sns.boxplot(data=df_speed_pl, x='bin', y='tok_speed', showfliers=False, hue='wd', palette=['#1f77b4', '#ff7f0e'], ax=ax)\n",
    "    ax.grid(True)\n",
    "    ax.set_xlabel('', fontsize=17)\n",
    "    ax.set_ylabel(r'Token Speed $(0-1)$', fontsize=17)\n",
    "    \n",
    "    # Round the weight decay values to 1 decimal place for the legend\n",
    "    handles, labels = ax.get_legend_handles_labels()\n",
    "    labels = [f'{float(label):.1f}' for label in labels]\n",
    "    ax.legend(handles, labels, title='Weight Decay')\n",
    "\n",
    "    bins = df_speed_pl['bin'].unique()\n",
    "    ax.set_xticks(range(len(bins)))\n",
    "    ax.set_xticklabels([])\n",
    "\n",
    "    ax2 = ax.twiny()\n",
    "    ax2.set_xlim(ax.get_xlim())\n",
    "    ax2.set_xlabel('Percentage of Tokens per Bin', fontsize=16)\n",
    "\n",
    "    ax2.set_xticks(range(len(bins)))\n",
    "    bin_proportions_labels = [f'{p:.2f}%' for p in bin_proportions]\n",
    "    ax2.set_xticklabels(bin_proportions_labels)  # Proportions displayed at the top\n",
    "\n",
    "    # ax.text(1.0, ax.get_ylim()[0] - 0.02, 'Low-frequency', ha='center', va='top', fontsize=17, bbox=dict(facecolor='white', alpha=0.5))\n",
    "    # ax.text(len(bins) - 2.0, ax.get_ylim()[0] - 0.02, 'High-frequency', ha='center', va='top', fontsize=16, bbox=dict(facecolor='white', alpha=0.5))\n",
    "\n",
    "    # save to disk.\n",
    "    if save:\n",
    "        wdstr_left = str(round(wds[0]*100)).zfill(3)\n",
    "        wdstr_right = str(round(wds[1]*100)).zfill(3)\n",
    "        plt.savefig(f\"{outdir}/speed-loss-wd-{wdstr_left}-vs-{wdstr_right}.pdf\", bbox_inches='tight', pad_inches=0.1)\n",
    "        #plt.savefig(f\"{outdir}/speed-loss-wd-{wdstr_left}-vs-{wdstr_right}.png\", bbox_inches='tight', pad_inches=0.1, dpi=300)\n",
    "\n",
    "    if abs(wds[0] - 0.1) < 1e-6 and abs(wds[1] - 1.0) < 1e-6:\n",
    "        plt.show()\n",
    "    \n",
    "    plt.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "id": "2cdb98ae",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "generate plot for wd=0.0 vs wd=2.0                                                                  \r"
     ]
    }
   ],
   "source": [
    "ref = wds[0]\n",
    "for i, wd in enumerate(wds):\n",
    "    if wd <= ref: continue\n",
    "    outdir = f\"iclr-plots/speed/{exp}\"\n",
    "    os.makedirs(outdir, exist_ok=True)\n",
    "    impair_speed_plot(df, [ref, wd], save=True, outdir=outdir)\n",
    "    print(f\"generate plot for wd={round(ref, 2)} vs wd={round(wd, 2)}\".ljust(100), end='\\r')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 84,
   "id": "595c69b5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "generate plot for wd=0.1 vs wd=0.8                                                                  \r"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA1wAAAF6CAYAAAANj1nGAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAAB4pklEQVR4nO3dd3xTVf8H8E/SlbbQFOikkJZVZMgqQ5CHvdQfW4YilC0oylAUZDpK4QEB4YGnFgVkCYigPIAoVIqAyBJQQbBAaaC0ZXfRnfP7g1cjMWmbNDe9Sft5v168au8995xv7smN+fbce45CCCFAREREREREklPKHQAREREREVF5xYSLiIiIiIjIRphwERERERER2QgTLiIiIiIiIhthwkVERERERGQjTLiIiIiIiIhshAkXERERERGRjTDhIiIiIiIishEmXERERERERDbChIuIHFJISAgUCoXBPzc3N2g0GgwZMgRHjhyRO0RyEOvWrUPLli3h6empfy9dv37dZNnr168bve/M+Tdy5EiLYpo/fz4UCgXmz59v9esjaY0cOdJkH6tUKtSpUwejR4/GH3/8YfLY9evXl+r9QESOzVnuAIiIrPHss8+ibt26AICHDx/i9OnT2L59O7766issWbIE06ZNkzlC+YWEhCAhIQHx8fEICQmROxy7snfvXowePRoqlQrdunVDtWrVAACVKlUyWb5SpUoIDw832n7lyhUcO3YMnp6eePHFF432t2/fXtrASXZ16tQx6Ne7d+/i9OnTWLduHTZt2oSvv/4avXv3ljFCIrIXTLiIyKGNHTvW4K/F2dnZePXVV7Fhwwa88847+L//+z+EhobKFyDZta+++goAsGLFCowbN67E8j4+Pli/fr3R9vXr1+PYsWNF7qfyp3379kZ9nZ2djfDwcGzfvh3jxo3DzZs34ez891et/v3745lnnoFarS7jaIlITrylkIjKFZVKhVWrVsHT0xMFBQXYuXOn3CGRHdNqtQCAevXqyRwJlQcqlQoREREAgJSUFFy4cMFgv1qtxlNPPYXAwEA5wiMimTDhIqJyp1KlSqhfvz4AGD2L89dff+HVV19FnTp1oFKpoFar0aFDB2zatMlkXZ06dYJCoUBsbCyOHDmC3r17w9fXF0ql0uCv248ePcLy5cvRvn17VKlSBW5ubggODkbv3r2xZcsWk3Xv2LED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e6PRaBAdHS15nURERGXNZgnXrVu3sH37dsTFxcHV1RVNmzbFiy++iEqVKtmqSSIiKidUKhVHo4iIqFywOOFKTEzE+++/DycnJ3zyySdwdXU1KvPll19i7NixyM7ONtg+e/Zs7N69Gy1atCh9xERERERERA7C4oTr+++/x2effYY+ffqYTLbOnTuH8PBw5OfnQ6lUol69evDw8MBvv/2GW7duoXfv3rh06RIqVy7fz4sosx7KHYIRRU663CEQEREREVUoFidcP/74IxQKBV566SWT+z/88EPk5+fD29sbe/bsQbt27QAAFy9eRPfu3ZGcnIzPPvsMU6dOtS5yO+ce/5PcIRARERERkcwsTrguXLgAAOjcubPRvqysLOzZswcKhQIzZ87UJ1sA0LBhQ8ydOxcTJ07E3r17y33ClVWrA3Tu3nKHYcDp4Q2obp2VOwwiIiIiogrD4oQrKSkJlSpVgp+fn9G+X375BXl5eVAoFBg6dKjR/sGDB2PixIn6pK0807l7Q+fpI3cYBgpvc7S3RW7tLR4iIiIiIqlYnHA9ePAA7u7uJvedOHECABAUFISaNWsa7a9SpQo8PT3x4MEDS5slCXG9JSIiIiKismFxwlW5cmU8ePAA6enpRhNf/PLLLwCAli1bFnm8UqmEQqGwtFmSEBfdJSIiIiIqGxYnXA0bNsSxY8ewY8cOjBo1Sr/90aNH+gk12rdvb/LY1NRUpKenc/FJmXHRXSIiIiKisqG09IC+fftCCIE5c+bg3LlzAIDc3FxMnjwZGRkZUCgUGDhwoMljf/75ZwBAgwYNSh8xERERERGRg7B4hGvChAlYuXIlbty4gbCwMPj7++P+/fv6yTJeeuklBAcHmzx2+/btxY6AERERERERlScWj3B5enri+++/R2hoKIQQSE5ORm5uLoQQePbZZ7Fq1SqTx92+fRvbt28HADz//PPWRU1EREREROQALB7hAoD69evj999/x8GDB/HHH38AAMLCwkyuzVXozp07+Pe//w0XFxc0b968dNESERERERE5kFIlXADg7OyMXr16oVevXmaVb9SoERo1alTa5oiIiIiIiByOxbcUEhERERERkXmYcBEREREREdkIEy4iIiIiIiIbKfUzXERE1sjOzoZWqy2xXEJCgsHPkmg0GqhUKqtiIyIiIpIKEy4ikoVWq8X48ePNLh8REWFW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",
      "text/plain": [
       "<Figure size 1000x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "generate plot for wd=0.1 vs wd=2.0                                                                  \r"
     ]
    }
   ],
   "source": [
    "ref = wds[1]\n",
    "for i, wd in enumerate(wds):\n",
    "    if wd <= ref: continue\n",
    "    outdir = f\"iclr-plots/speed/{exp}\"\n",
    "    os.makedirs(outdir, exist_ok=True)\n",
    "    impair_speed_plot(df, [ref, wd], save=True, outdir=outdir)\n",
    "    print(f\"generate plot for wd={round(ref, 2)} vs wd={round(wd, 2)}\".ljust(100), end='\\r')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5c223e1c",
   "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.14"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
