{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "# autoreload magic\n",
    "%reload_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "\n",
    "\n",
    "from mindreadingautobots.analysis.analysis_config import SPREADSHEET_NAMES, BF_VALS, NAME_TEMPLATES, DATASET_NAMES\n",
    "from mindreadingautobots.analysis.analysis_config import spreadsheet_to_dataframe\n",
    "target_directory = \"../processed/\""
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Extra analysis: Improved LSTM hypers versus original transformer hypers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading: RNN_sparse_parity_k4_nbits21_n5000_bf0_seed1234_results\n",
      "Loading: RNN_sparse_parity_k4_nbits21_n5000_bf1_seed1234_results\n",
      "Loading: RNN_sparse_parity_k4_nbits21_n5000_bf2_seed1234_results\n",
      "Loading: RNN_sparse_parity_k4_nbits21_n5000_bf5_seed1234_results\n",
      "Loading: RNN_sparse_parity_k4_nbits21_n5000_bf7.5_seed1234_results\n"
     ]
    }
   ],
   "source": [
    "# download the latest smajority data\n",
    "bf_vals = [0, 1, 2, 5, 7.5]\n",
    "sheetname_template = NAME_TEMPLATES[4] + \"_results\"\n",
    "df_sparity_rerun = spreadsheet_to_dataframe(\"LSTM_sparity_21_4_good_hyper\", bf_vals, sheetname_template, models=[\"RNN\"])\n",
    "# df.to_csv(f\"./processed/{SPREADSHEET_NAME}.csv\", index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading: SAN_sparse_parity_k4_nbits21_n5000_bf1_seed1234_results\n",
      "Loading: SAN_sparse_parity_k4_nbits21_n5000_bf2_seed1234_results\n",
      "Loading: SAN_sparse_parity_k4_nbits21_n5000_bf5_seed1234_results\n"
     ]
    }
   ],
   "source": [
    "bf_vals = [1, 2, 5]\n",
    "sheetname_template = NAME_TEMPLATES[4] + \"_results\"\n",
    "df_sparity_san_rerun = spreadsheet_to_dataframe(\"Extra_SAN_SPARITY_21_4_most_fail\", bf_vals, sheetname_template, models=[\"SAN\"])\n",
    "# df.to_csv(f\"./processed/{SPREADSHEET_NAME}.csv\", index=False)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading: SAN_sparse_parity_k4_nbits21_n5000_bf7.5_seed1234_results\n",
      "Loading: SAN_sparse_parity_k4_nbits21_n5000_bf10_seed1234_results\n"
     ]
    }
   ],
   "source": [
    "bf_vals = [7.5, 10]\n",
    "sheetname_template = NAME_TEMPLATES[4] + \"_results\"\n",
    "df_sparity_san_rerun_2 = spreadsheet_to_dataframe(\"Extra_SAN_SPARITY_21_4_percentage_check\", bf_vals, sheetname_template, models=[\"SAN\"])\n",
    "# df.to_csv(f\"./processed/{SPREADSHEET_NAME}.csv\", index=False)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\peter\\AppData\\Local\\Temp\\ipykernel_14552\\2238379642.py:2: RuntimeWarning: invalid value encountered in scalar divide\n",
      "  return np.sum(np.abs(accs - target) < epsilon) / len(accs)\n",
      "C:\\Users\\peter\\AppData\\Local\\Temp\\ipykernel_14552\\2238379642.py:2: RuntimeWarning: invalid value encountered in scalar divide\n",
      "  return np.sum(np.abs(accs - target) < epsilon) / len(accs)\n",
      "C:\\Users\\peter\\AppData\\Local\\Temp\\ipykernel_14552\\2238379642.py:2: RuntimeWarning: invalid value encountered in scalar divide\n",
      "  return np.sum(np.abs(accs - target) < epsilon) / len(accs)\n",
      "C:\\Users\\peter\\AppData\\Local\\Temp\\ipykernel_14552\\2238379642.py:2: RuntimeWarning: invalid value encountered in scalar divide\n",
      "  return np.sum(np.abs(accs - target) < epsilon) / len(accs)\n",
      "C:\\Users\\peter\\AppData\\Local\\Temp\\ipykernel_14552\\2238379642.py:2: RuntimeWarning: invalid value encountered in scalar divide\n",
      "  return np.sum(np.abs(accs - target) < epsilon) / len(accs)\n",
      "C:\\Users\\peter\\AppData\\Local\\Temp\\ipykernel_14552\\2238379642.py:2: RuntimeWarning: invalid value encountered in scalar divide\n",
      "  return np.sum(np.abs(accs - target) < epsilon) / len(accs)\n",
      "C:\\Users\\peter\\AppData\\Local\\Temp\\ipykernel_14552\\2238379642.py:2: RuntimeWarning: invalid value encountered in scalar divide\n",
      "  return np.sum(np.abs(accs - target) < epsilon) / len(accs)\n",
      "C:\\Users\\peter\\AppData\\Local\\Temp\\ipykernel_14552\\2238379642.py:2: RuntimeWarning: invalid value encountered in scalar divide\n",
      "  return np.sum(np.abs(accs - target) < epsilon) / len(accs)\n",
      "C:\\Users\\peter\\AppData\\Local\\Temp\\ipykernel_14552\\2238379642.py:2: RuntimeWarning: invalid value encountered in scalar divide\n",
      "  return np.sum(np.abs(accs - target) < epsilon) / len(accs)\n",
      "C:\\Users\\peter\\AppData\\Local\\Temp\\ipykernel_14552\\2238379642.py:2: RuntimeWarning: invalid value encountered in scalar divide\n",
      "  return np.sum(np.abs(accs - target) < epsilon) / len(accs)\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABR8AAAIhCAYAAADHFs2PAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjAsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvlHJYcgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAi9ZJREFUeJzt3QmcTfX/+PH3bMaMZSxjJ0uU7EWERF9KUb5o0WZLKiWVsqWhSEK2JCKkFZX2oojKLnuFslO2sQ2zL+f/eH9+/zvfOxtzx9y599z7ej4ex8w9dzmfc8+M+5735/N5fwIsy7IEAAAAAAAAAPJZYH6/IAAAAAAAAAAoko8AAAAAAAAA3ILkIwAAAAAAAAC3IPkIAAAAAAAAwC1IPgIAAAAAAABwC5KPAAAAAAAAANyC5CMAAAAAAAAAtyD5CAAAAAAAAMAtSD4CAAAAAAAAcAuSjwBspU2bNmazq5UrV0pAQID56tCrVy+pVq3aJZ974MAB89x33303X9ukx9Y2AAAA+AN3xpPuite8zUsvvWTOMy8xpb43+lx9r/KLv7zvgF2RfASQ7xwBReHCheWff/7Jcr8Ge/Xq1fNI2/zVmjVrTJB49uxZTzcFAADgkognkZ2PPvpIpkyZ4ulmAHBRsKtPAIDcSkxMlNdee02mTZuWb6/5ww8/iK+ZPXu2pKWluT35+PLLL5ve6BIlSmS4b/fu3RIYSF8UAADwPsST9lEQMaUmH3///Xd55plnMuyvWrWqxMfHS0hIiFuPDyBv+GsTgNs0atTIJNb+/ffffHvNQoUKmc2XaJAUGhrqsePrsQnUAACANyKetA9PxpSOUbJBQUEeOT6AiyP5CMBtXnjhBUlNTTW91ZeSkpIio0ePliuvvNIELlozRp+vvd2XqtGjPeF169aV8PBwKVmypDRp0sT0iqoVK1aYYOTzzz/Pckx9jN63du3abNv022+/mfvnz5+f5b6lS5ea+7755htz++DBg/LEE0/I1VdfLWFhYVK6dGm55557clXLJruajzo9WvdHRESYkYo9e/bMdsr09u3bzeNq1KhhAq7y5cvLww8/LKdOnUp/jE63HjRokPm+evXqpt3OdXayq8+zb98+0/5SpUqZ9/WGG26Qb7/9Ntv6lYsWLZIxY8ZI5cqVTRvatm0re/bsueR5AwAA2CGedNDp3xpnlStXzry+Pn7u3Lm5Oo9du3bJ3XffbWIrjZf09b/66qsMj0lOTjYzVWrVqmUeo/HkjTfeKD/++GP6Y44dOya9e/c2cZe2oUKFCvLf//73ojHn66+/bmI2jVczGzZsmEnEnjlzxtz+9ddfTQx4xRVXmNevUqWKPPvss2ZU4aVkF1P+8ccf8p///MfEx9rmV155JdsZP19++aV07NhRKlasaI6r11CvpV57B71mGo/qeTjiWUcMnVPNx59++klatWolRYoUMTG1vlc7d+7Mtn6lxq+OWUIag+v7HBcXd8nzBnBpTLsG4Daa6OrRo4fprR46dKgJJnLyyCOPmCSfBmXPPfecrF+/XsaOHWuCg+wShw762gMGDDDPe/rppyUhIcEk5PT5DzzwgAlSNGj68MMPpUuXLhmeq/s0sGnevHm2r61BoSb1NLmmyT9nCxcuNIFp+/btze2NGzeaqc333XefCaw0AJoxY4Y5/p9//mkC2dyyLMsERqtWrZLHH39crrnmGvMeZG6D0mBUE4UaHGniUQO8WbNmma/r1q0zgVTXrl3lr7/+ko8//lgmT54skZGR5rllypTJ9vjHjx+XFi1amGBL31sNfPXadOrUST799NMs76P+MaBTbJ5//nk5d+6cjB8/Xh588EFzDQAAAOweTzriI+2M1diqf//+Jo76/vvvpU+fPhITE5NlGrAzjctatmwplSpVMuegiTCNLzt37iyfffZZemylSTBtr55H06ZNzetqZ/jmzZvllltuMY+56667zOs99dRTJvF24sQJEw8eOnQoxwUM7733Xhk8eLA5pqND2kH33XrrrSauVZ988omJAfv162diwA0bNpjE7JEjR8x9rtBE6c0332ySwo7z1jhVE5GZadKwaNGiMnDgQPNVk4YjRoww78GECRPMY4YPH25iTW2LxrRKH5uTZcuWye23327ieX1vNYGq56LXQt/TzO+Xvk/686bXQO9/5513pGzZsjJu3DiXzhtANiwAyGfz5s2z9L+XjRs3Wnv37rWCg4OtAQMGpN/funVrq27duum3t27dah7/yCOPZHid559/3uz/6aefMjxXN4f//ve/GV4rO8OGDbNCQ0Ots2fPpu87ceKEadfIkSMv+dyQkBDr9OnT6fsSExOtEiVKWA8//HD6vri4uCzPXbt2rWn/e++9l75vxYoVZp9+dejZs6dVtWrV9NtffPGF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Rsp9991n7hs8eLC5bRfJycly9uxZufvuu9OLr+v5Va9ePX0YtZ2Gietw8MOHD8uXX34pM2fONOfXqFEjqVatmplO9fvvv5vh71dccYV4q5SUFFm0aJG5FjfccIPZd/vtt8uxY8fk5MmTZprYjTfeKM8995z5ageFChWS48ePm58rx/8JNWvWlPHjx8vIkSPl008/Nffdeeed4u3056tly5Zy//33y+uvvy5JSUnm6759+0ydql69epnrFhERId5Mf87efPNNKVq0qPkdUVqX6siRI6bO1qFDh+Suu+6SYcOGybXXXivezleui4P+36XXSOuEqfj4eAkLC5PXXnvNfD9jxgxTq65Bgwbpn7EALo541HsRj3of4lHv5ktxjy/FpL50XRyISV3gQqISbrZnzx4rMjLS9NKeP38+Q9b/0KFDpsf2+++/t+wgc+/LggULTPuff/55Kzo62uxLTU219u3bZ9mhp8lBe5nUiy++aHXv3j3D4xzXzJv9+++/Vo8ePcww91tuuSX9WiidwlOiRAnru+++s7ydDmnX3rJixYpZNWrUsLp27Wpt377d3Pf111+bkQB6feLi4jzd1EvSHn/9uerdu7d19913WwkJCeb3Xn8/HOfavHlz0+tsB/r+N2zY0OrcubN18OBBM22nRYsWZupO06ZNzagGHSFghx5a/d1/9NFHTW9/lSpVrA4dOpjRGPpzpb2blSpVMr9PduBL18Xh+uuvt26++eb02/q746Cjs+677z4PtQywN+JR70Q86n2IR72Xr8U9vhKT+tp1cSAmzR2Sj17mp59+MkOqn3zyyQzTQnSKgv6irlmzxrIT/SBzBKwff/xx+pQXrYWgNWv0Q9ouw5AdH75Kh7w7poso/U9y4sSJZrqFt9P3XuseLV++PMuw9po1a2apv+Ot9ANLf4b0P/rff/89w31vv/22qYmifyR58++Gs5UrV5qpO85TWhyP0fsCAwOznKe3+vzzz63WrVtbhQoVsm6//Xbr+PHj6ffp1KqqVat67R96ma+L/hGufzjodLBdu3ZluE+nu+j/aTrtyg7sfF00CNVpn+fOnUvft3nzZqts2bLW/fffn77P8X+w1kO68847PdJWwBcQj3ov4lHvQjzqvewc9/hyTGr360JMmnckH72Q/uehAZ8GQtpD++eff1pDhw61KlSoYB0+fNiyG+deMz0f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",
      "text/plain": [
       "<Figure size 1600x600 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def fraction_within_epsilon_of_target(accs, target, epsilon=0.01):\n",
    "    return np.sum(np.abs(accs - target) < epsilon) / len(accs)\n",
    "\n",
    "\n",
    "bf_vals = BF_VALS[4]\n",
    "df_sparity = pd.read_csv(f\"{target_directory}{SPREADSHEET_NAMES[4]}.csv\")\n",
    "df_sparity_ana = pd.read_csv(f\"{target_directory}{SPREADSHEET_NAMES[4]}_ana.csv\")\n",
    "entropies = df_sparity_ana[\"entropy\"].values.flatten()\n",
    "\n",
    "fig, axes = plt.subplots(1, 2, figsize=(16, 6))\n",
    "entropies = df_sparity_ana[\"entropy\"].values.flatten()\n",
    "# make widths that are diffs of each consecutive entropy value\n",
    "diffs = np.diff(entropies)\n",
    "# add a final width of 1 - last entropy value\n",
    "widths = np.concatenate([diffs, [1 - entropies[-1]]])\n",
    "# fig, axes = plt.subplots(len(bf_vals), 2, figsize=(6, 12), sharex=True, sharey=True, constrained_layout=True)\n",
    "zzz = True\n",
    "for i, bf in enumerate(bf_vals):\n",
    "    df_rnn_bf = df_sparity.loc[df_sparity[\"bf\"] == bf].loc[df_sparity[\"model\"] == \"RNN\"]\n",
    "    df_san_bf = df_sparity.loc[df_sparity[\"bf\"] == bf].loc[df_sparity[\"model\"] == \"SAN\"]\n",
    "    df_rnn_rerun_bf = df_sparity_rerun.loc[df_sparity_rerun[\"bf\"] == bf] # the rerun sheet has a different format\n",
    "    df_san_rerun_bf = df_sparity_san_rerun.loc[df_sparity_san_rerun[\"bf\"] == bf]\n",
    "    df_san_rerun_bf_2 = df_sparity_san_rerun_2.loc[df_sparity_san_rerun_2[\"bf\"] == bf]\n",
    "\n",
    "    mle_noiseless = df_sparity_ana.loc[df_sparity_ana[\"bf\"] == bf/100][\"mle_noiseless\"].values.flatten()\n",
    "    mle_noisy = df_sparity_ana.loc[df_sparity_ana[\"bf\"] == bf/100][\"mle_noisy\"].values.flatten()\n",
    "\n",
    "    epsilon = 0.05\n",
    "    # compute fractions of models that achieved (noisy) MLE performance\n",
    "    san_val_frac = fraction_within_epsilon_of_target(df_san_bf['val_acc'].values, mle_noisy, epsilon=epsilon)\n",
    "    rerun_rnn_val_frac = fraction_within_epsilon_of_target(df_rnn_bf['val_acc'].values, mle_noisy, epsilon=epsilon)\n",
    "    rnn_val_frac = fraction_within_epsilon_of_target(df_rnn_rerun_bf['val_acc'].values, mle_noisy, epsilon=epsilon)\n",
    "    san_rerun_val_frac = fraction_within_epsilon_of_target(df_san_rerun_bf['val_acc'].values, mle_noisy, epsilon=epsilon)\n",
    "    san_rerun_val_frac_2 = fraction_within_epsilon_of_target(df_san_rerun_bf_2['val_acc'].values, mle_noisy, epsilon=epsilon)\n",
    "\n",
    "    width = 1\n",
    "    axes[0].bar(i, san_rerun_val_frac, width=width, color='g', alpha=0.5, align='center', edgecolor='k', label=\"extra SAN most failed\" if zzz else None)\n",
    "    axes[0].bar(i, rerun_rnn_val_frac, width=width, color='y', alpha=0.5, align='center', edgecolor='k', label=\"rerun LSTM\" if zzz else None)\n",
    "    axes[0].bar(i, san_val_frac, width=width, color='b', alpha=0.5, align='center', edgecolor='k', label=\"original SAN\" if zzz else None)\n",
    "    axes[0].bar(i, rnn_val_frac, width=width, color='r', alpha=0.5, align='center', edgecolor='k', label=\"original LSTM\" if zzz else None)\n",
    "    axes[0].bar(i, san_rerun_val_frac_2, width=width, color='m', alpha=0.5, align='center', edgecolor='k', label=\"extra SAN percentage check\" if zzz else None)\n",
    "    zzz = False\n",
    "    axes[0].legend(loc=\"upper right\")\n",
    "    axes[0].set_title(\"Noisy validation\")\n",
    "    axes[0].set_ylabel(f\"Fraction of runs within {epsilon*100}% of optimal\")\n",
    "    # compute fractions of models that achieved (noiseless) MLE performance\n",
    "    san_noiseless_val_frac = fraction_within_epsilon_of_target(df_san_bf['noiseless_val_acc'].values, mle_noiseless, epsilon=epsilon)\n",
    "    rnn_noiseless_val_frac = fraction_within_epsilon_of_target(df_rnn_bf['noiseless_val_acc'].values, mle_noiseless, epsilon=epsilon)\n",
    "    rerun_rnn_noiseless_val_frac = fraction_within_epsilon_of_target(df_rnn_rerun_bf['noiseless_val_acc'].values, mle_noiseless, epsilon=epsilon)\n",
    "    san_rerun_noiseless_val_frac = fraction_within_epsilon_of_target(df_san_rerun_bf['noiseless_val_acc'].values, mle_noiseless, epsilon=epsilon)\n",
    "    san_rerun_noiseless_val_frac_2 = fraction_within_epsilon_of_target(df_san_rerun_bf_2['noiseless_val_acc'].values, mle_noiseless, epsilon=epsilon)\n",
    "    \n",
    "    axes[1].bar(i, san_noiseless_val_frac, width=width, color='b', alpha=0.5, label='SAN [noiseless]', align='center', edgecolor='k')\n",
    "    axes[1].bar(i, rnn_noiseless_val_frac, width=width, color='r', alpha=0.5, label='RNN [noiseless]', align='center', edgecolor='k')\n",
    "    axes[1].bar(i, rerun_rnn_noiseless_val_frac, width=width, color='y', alpha=0.5, label='RNN [rerun] [noiseless]', align='center', edgecolor='k')\n",
    "    axes[1].bar(i, san_rerun_noiseless_val_frac, width=width, color='g', alpha=0.5, label='SAN [rerun] [noiseless]', align='center', edgecolor='k')\n",
    "    axes[1].bar(i, san_rerun_noiseless_val_frac_2, width=width, color='m', alpha=0.5, label='SAN [rerun 2] [noiseless]', align='center', edgecolor='k')\n",
    "    axes[1].set_title(\"Noiseless validation\")\n",
    "\n",
    "\n",
    "entropy_rounded = np.round(entropies, 3)\n",
    "for ax in axes:\n",
    "    ax.set_xticks(range(len(bf_vals)), bf_vals, rotation=45, ha='right')\n",
    "    # ax.set_xticks(range(len(bf_vals)), entropy_rounded, rotation=45, ha='right')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([14.42188625,  0.        ,  0.07210943,  0.        ,  0.07210943,\n",
       "         0.        ,  0.        ,  0.07210943,  0.        ,  6.99461483]),\n",
       " array([0.50139776, 0.5476238 , 0.59384984, 0.64007588, 0.68630192,\n",
       "        0.73252796, 0.77875399, 0.82498003, 0.87120607, 0.91743211,\n",
       "        0.96365815]),\n",
       " <BarContainer object of 10 artists>)"
      ]
     },
     "execution_count": 55,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots()\n",
    "df_san_rerun_bf = df_sparity_san_rerun.loc[df_sparity_san_rerun[\"bf\"] == 1]\n",
    "df_san_original = df_sparity.loc[df_sparity[\"bf\"] == 1].loc[df_sparity[\"model\"] == \"SAN\"]\n",
    "# print(df_san_rerun_bf[\"val_acc\"].values)\n",
    "# print(df_san_original[\"val_acc\"].values)\n",
    "ax.hist(df_san_rerun_bf[\"val_acc\"].values, alpha=0.5, color='r', density=True)\n",
    "ax.hist(df_san_original[\"val_acc\"].values, alpha=0.5, density=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([0.        , 0.        , 0.        , 0.        , 0.        ,\n",
       "        0.        , 0.        , 0.10285842, 0.25714606, 0.09714407,\n",
       "        0.16000199, 0.26857478, 0.22857428, 0.25714606, 0.20000249,\n",
       "        0.14857328, 0.18857378, 0.19428814, 0.26286042, 0.26286042,\n",
       "        0.20571685, 0.18285942, 0.22285992, 0.18857378, 0.        ,\n",
       "        0.        , 0.        , 0.        , 0.        , 0.        ]),\n",
       " array([-11.51292546, -11.22126243, -10.9295994 , -10.63793637,\n",
       "        -10.34627334, -10.05461031,  -9.76294727,  -9.47128424,\n",
       "         -9.17962121,  -8.88795818,  -8.59629515,  -8.30463211,\n",
       "         -8.01296908,  -7.72130605,  -7.42964302,  -7.13797999,\n",
       "         -6.84631696,  -6.55465392,  -6.26299089,  -5.97132786,\n",
       "         -5.67966483,  -5.3880018 ,  -5.09633876,  -4.80467573,\n",
       "         -4.5130127 ,  -4.22134967,  -3.92968664,  -3.6380236 ,\n",
       "         -3.34636057,  -3.05469754,  -2.76303451]),\n",
       " <BarContainer object of 30 artists>)"
      ]
     },
     "execution_count": 64,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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t956a/zyl7+Myy67LH+vxsydOze6d+9ef6THTABA63VcF4675ZZb4sEHH8y9KWnAbsWECRPqvz7nnHNiyJAhceaZZ+Zyn/jEJ95Vz4wZM/I4morUwyK0AEDrVVUPS48ePaJ9+/axdevWBtfTeRp3cji33357Diw///nPcyA5nAEDBuTv9fLLLzf6ehrv0q1btwYHANB6VRVYOnToEMOHD28wYLYygHb06NGHvG/evHkxZ86cWL58eYwYMeI9v8+rr76ax7D07t27muYBAK1U1bOE0qOYtLbK/fffH88//3weILt79+48ayiZNGlSfmRTkcak3HTTTXkWUVq7JY11Scdbb72VX0//Xn/99fHEE0/EK6+8ksPP5ZdfHgMHDszTpQEAqh7DMn78+Ni+fXvMnDkzB480XTn1nFQG4m7YsCHPHKpYtGhRnl30uc99rkE9aR2X2bNn50dMzzzzTA5AO3fuzANy0zotqUcmPfoBAGjSoNtp06blozFpoOzBUq/J4XTu3DkeffTRpjQDAGgj7CUEABRPYAEAiiewAADFE1gAgOIJLABA8QQWAKB4AgsAUDyBBQAonsACABRPYAEAiiewAADFE1gAgOIJLABA8QQWAKB4AgsAUDyBBQAonsACABRPYAEAiiewAADFO6mlGwDNYvbspt/7/z4fbckdK15s6SYAVE0PCwBQPIEFACiewAIAFE9gAQCKJ7AAAMUzSwiAFp+B9qVmbQmtkR4WAKB4AgsAUDyBBQAonsACABRPYAEAiiewAADFE1gAgOIJLABA8QQWAKB4AgsAUDyBBQAonsACABRPYAEAiiewAADFE1gAgOIJLABA8QQWAKB4AgsAUDyBBQAonsACABTvpJZuAADN644VLzb53i998sPN2hZoLnpYAIDWGVgWLlwY/fv3j06dOsWoUaNizZo1hyx7zz33xIUXXhinnnpqPsaMGfOu8nV1dTFz5szo3bt3dO7cOZd56aWXmtI0AKAVqjqwLFu2LKZPnx6zZs2KdevWxdChQ2Ps2LGxbdu2RsuvWrUqJk6cGI899lisXr06+vXrF5dcckls2rSpvsy8efPizjvvjMWLF8eTTz4ZJ598cq7z7bffPrp3BwC0zcAyf/78mDp1akyZMiUGDx6cQ0aXLl1iyZIljZb/8Y9/HNdee20MGzYsBg0aFPfee28cOHAgVq5c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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots()\n",
    "cts, bins, _ = ax.hist(np.log(df_san_original[\"lr\"].values), alpha=0.5, color='r', density=True, bins=30)\n",
    "ax.hist(np.log(df_san_rerun_bf[\"lr\"].values), alpha=0.5, density=True, bins=bins)\n",
    "\n",
    "# for col in [\"depth\", \"d_model\", \"heads\", \"d_ffn\"]:\n",
    "#     fig, ax = plt.subplots()\n",
    "#     ax.hist(df_san_original[col].values, alpha=0.5, color='r', density=True)\n",
    "#     ax.hist(df_san_rerun_bf[col].values, alpha=0.5, density=True)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "600"
      ]
     },
     "execution_count": 54,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(df_san_rerun_bf)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "np.float64(0.0)"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "rnn_noiseless_val_frac"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": ".venv",
   "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.11.1"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
