{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# autoreload magic\n",
    "%reload_ext autoreload\n",
    "%autoreload 2\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "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: We can significantly improve Ham(6, 6) hypers for LSTM."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading: RNN_hamilton_6_choose_6_nbits11_n5000_bf0_seed1234_results\n",
      "Loading: RNN_hamilton_6_choose_6_nbits11_n5000_bf10_seed1234_results\n",
      "Loading: RNN_hamilton_6_choose_6_nbits11_n5000_bf20_seed1234_results\n"
     ]
    }
   ],
   "source": [
    "# Get existing hamiltonian data\n",
    "bf_vals = BF_VALS[5]\n",
    "df_ham_original = pd.read_csv(f\"{target_directory}{SPREADSHEET_NAMES[5]}.csv\")\n",
    "df_ham_ana = pd.read_csv(f\"{target_directory}{SPREADSHEET_NAMES[5]}_ana.csv\")\n",
    "entropies = df_ham_ana[\"entropy\"].values.flatten()\n",
    "\n",
    "bf_vals = [0, 10, 20]\n",
    "sheetname_template = NAME_TEMPLATES[5]\n",
    "df_ham_rerun_rnn = spreadsheet_to_dataframe(\"haniltonian_rerun\", bf_vals, sheetname_template, models=[\"RNN\"])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABLkAAAHDCAYAAADIusjNAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjAsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvlHJYcgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAdUFJREFUeJzt3Qd8VFX+/vEvkE4KvQkINkBZRVEUdRWVFctaVtfe9WfHVbCh2AtgBQvWBdH/qrg2dm1YEHVd0VUEFUQQBEGB0NJ7mf/rOe5kJ2ESMsmU3Mzn/dpZkin3nrkZc598z7nntPH5fD4DAAAAAAAAPKxtrBsAAAAAAAAANBdFLgAAAAAAAHgeRS4AAAAAAAB4HkUuAAAAAAAAeB5FLgAAAAAAAHgeRS4AAAAAAAB4HkUuAAAAAAAAeB5FLgAAAAAAAHgeRS4AAAAAAAB4HkUuwONWrVplbdq0sRkzZtTcd9ttt7n7GkPP0/PDacSIEe4GAADQ0kUytwTLaa3RRx995N6n/vU799xzrV+/fjE7Rtq32gAgvlDkAqLo2GOPtbS0NCsoKKj3OWeccYYlJSXZ5s2brSX7/vvvXXFMwaQlevvtt11g6tWrl1VXV8e6OQAAoBlUANF5PSUlxX799detHleRavDgwTFpm9fsvvvu1rdvX/P5fPU+54ADDrDu3btbZWWltWSfffaZy6O5ubnWEj322GPuc7vvvvvGuilA3KDIBUSRClglJSX2+uuvB328uLjY/vGPf9gRRxxhnTt3bvJ+brrpJrefSBe5br/99qBFrvfee8/dYun55593PXjr1q2zDz/8MKZtAQAA4VFWVmaTJk0K6zZbQm6Jdh5ds2aN/etf/wr6uLLdvHnz7JRTTrGEhIQm7+fpp5+2pUuXWqSLXMqjwYpc2rfa0BLy6H/+8x9bvnx5TNsCxAuKXECUR3JlZGTYCy+8EPRxFbiKiopc+GgOBRL1dMaKRqLpFis6hjqWY8eOtT333NMFjJZKbQUAAI0zZMgQV7hYu3Ztq8kt0Xb66ae70UX15dEXX3zRjfJqbh5NTEy05ORkixXtW22IlZUrV7oi3IMPPmhdu3YljwJRQpELiKLU1FQ74YQTbM6cObZhw4atHlfYUBFMxbAtW7bYNddcY7/73e8sPT3dMjMz7cgjj7Rvvvlmm/sJNieXej7HjBnjTrL+ffzyyy9bvfbnn3+2yy67zAYMGODaqxFlJ510Uq0RW7pkQPfJIYcc4vYVOA9DsLkt9H4vuOACN/RdBbg99tjDnn322aBzMtx///321FNP2Y477ugCyj777GNffvmlNZZGymkkm9p46qmn2muvvWalpaVbPU/36Vjtsssurk09e/Z0P58VK1bUPEeXOj700EPu56Dn6PhppN1XX321zXkk6s535v+5aBScAmbHjh3twAMPdI99++23bt6IHXbYwe2nR48edv755we9bFWXaehY6lJMHZ/+/fvbpZdeauXl5fbTTz+5fUyePHmr1ylo6TGFVwAAvOjGG2+0qqqqRo3m0qV2d955Z02e0IgavV6ZKFCw3PLII4/Ybrvt5qaZ0Pl677333qoopPOxztXKNtq+nj99+vRGvY8ffvjB/vznP1unTp3ceV/b/+c//1nrORUVFW6U0s477+yeo0ym3PD+++/XPGf9+vV23nnnWe/evV0blGWOO+64BqeT6NOnjx100EH2yiuvuH3UpfepY6ZL7BqTC+sTbE4ujbjS/VlZWdahQwc755xzgo7CakwuUq669tpr3dfKQv486m9bsDm5lJPUfh13/Wz3228/e+utt4LOL/b3v//d7r77bnds1YbDDjsspNFYKmrps3P00Ue7n3V9RS69f2V0tVc/Q+3v7LPPtk2bNjU6swabE62+nKpjor8t9NqjjjrK/V3gL2hqdJ+Ojy5nVVv0WVHbgl0hos/wySef7LKxPhv6jIwfP949NnfuXLffYFev6POlxzRaEIiEpo8/BdAkOomouKMT5+jRo2vuV1Hr3XfftdNOO82dKBYvXmyzZs1yJxqduLOzs+3JJ5+0gw8+2BVJVOAIxf/93//Z3/72N1dc2X///d0lfDrp1qVikoohKg7pJKuT4+OPP+7Cn/arQKBg9Je//MUefvhhFxYHDRrkXuv/ty6dGPV6BQO9Z72fl19+2Z1kdWK/8sortzr5ad6yiy++2J0E7733XnciVzBpTI+cQoSKbwpEeh/jxo2zN954o6YwJwrIf/zjH13BUc9RG7RPBcdFixa5cCcqJikYqMCoY6jArADw+eefu0DaFGqHAuuECRNq5sPQfvX+FFTVbv38VejTv9qXv2ipnuthw4a543bRRRfZwIEDXchWUNXlrgqDmkdDx0ChpO5xUZBR+AUAwIuUIVQA0Ggund8bykM6bytzqcBw9dVX2xdffGETJ060JUuW1Dt1hGjbyjl6nfKBCgwquuj1ylGiXKYCic7Pyjb6Q/+dd95xuSE/P9+uuuqqerevc7vO1dttt517D+3bt3e58Pjjj7dXX33V/vSnP7nnqaih9up96Nyv7aqT7euvv7Y//OEP7jknnnii294VV1zhiiTqVFSmWL16dYOTviuPKkcoeyoP+X333XcuB91yyy2NzoWNpcyjDPLpp5/aJZdc4nKjfg4qdNXVmFykbLhs2TLXeafOvS5durjX6mcRjH5mysDKS/r5qmCnz4c6fpWj/MfdT4XUtm3buk7nvLw8l0d13PQ5aAzlLrVRowSV73XcdDzVeetXWFhov//9791nUkW8vfbayxW3VPBUZ7TeU2MzayiUZ0eNGuWKpupc9v8clc91fNR5quOjyyxV8FVb9Jif/ntQu5XL9TnSZ01FM+VtFQb1+VCBTMeg7nHVfWrz8OHDQ2430Cg+AFFVWVnp69mzp2/48OG17n/iiSdU7fC9++677vvS0lJfVVVVreesXLnSl5yc7Lvjjjtq3afXPfPMMzX33Xrrre4+v4ULF7rvL7vsslrbO/300939er5fcXHxVm2eN2+ee95zzz1Xc9/LL7/s7ps7d+5Wzz/44IPdzW/KlCnuuX/7299q7isvL3fHID093Zefn1/rvXTu3Nm3ZcuWmuf+4x//cPe/8cYbvm3Jzs72JSQk+J5++uma+/bff3/fcccdV+t506dPd9t88MEHt9pGdXW1+/fDDz90z/nLX/5S73OCHX+/usfW/3M57bTTtnpusOP+4osvuud/8sknNfedffbZvrZt2/q+/PLLetv05JNPutctWbKk1vHu0qWL75xzztnqdQAAtHQ6z+rcpvPfihUr3Lk+8Pys3LHbbrttlX3+7//+r9Z2rrnmGne/zvH15RZlhsBtBXPBBRe4PLdp06Za95966qm+rKysmvN6sJxw2GGH+X73u9+5rBd4Dlde2XnnnWvu22OPPXxHH310vW3Iyclx277vvvt8oVLOUqasm0nGjRvntrl06dKQcqHyYN1cqMyx/fbb13w/a9Ys95x77723Vi7+/e9/v9Uxamwu0nvXfTrOdWnfgbnnqquucs/917/+VXNfQUGBr3///r5+/frV5G7/exk0aJCvrKys5rkPPfSQu/+7777zbctX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efrpp3077LCDr127drWWLa7bRsnOzq7ZblJSkls6O7DNge8l2FLYddtZ1xVXXOGeo2XF63Pbbbe553zzzTc1yySPHz/eLR2dmJjo69Gjh+/Pf/5zrW1oaWu1Z+DAga7dXbt29R155JG++fPn1zxH29FS4loyXMspn3zyyW6J5Lpt9v9cNm7cuFXbfvnlF9+f/vQnX4cOHdx2TjrpJN/atWuDvm8t13z22We7tmhpZv0MLr/88lrLXPtpCfS2bdu67QMA4FXKDDonfvnll1s9pnyix3TOC1RRUeG7/fbba87zffr08d1www0uYwWqm1uefPJJ30EHHeQyk86zO+64o+/aa6/15eXlbZVtdP7Vdv054rDDDvM99dRTDeY0UdbQuVyv0Wu322473x//+EffK6+8UvOcu+66y2VEZQNlQWWRu+++21deXu4e37Rpk9u/7le2U37Yd999fX//+99DOrZ6b2qj8ktdjc2FyoCBWdD/c9HzAm3evNl31lln+TIzM1179fWCBQu2Okah5KI777zTHT/lHT2uYy7BsquOu7KetpuSkuKO75tvvlnrOf738vLLL9e6v76fZSDla223qKio3uece+657meun5//mIwePdq9B2XN3r17u3b7H29sZlW+PPHEE31paWm+jh07+i6++GLfokWLtmqztq3PSzDff/+9b+TIke5nrZ/5hRde6HJzsPetbft/RnrPAwYM8N18881bbVP5VO3Rz1F/jwCR1kb/F/lSGgAgFjTprHoqA1fyAQAAAKJBl6hqtXKNsKs71zAQCczJBQCtlC5r0JDxwMlDAQAAgGjRyp+a7408imhhJBcAtDKaBFdzn2klJE1U+tNPP1lKSkqsmwUAAIA4oflytbq65uHSZPOarw6IBkZyAUArowlMtWCBJmvVBKsUuAAAABBNWkXz0ksvdYtSaeJ8IFoYyQUAAAAAAADPYyQXAAAAAAAAPI8iFwAAAAAAADwvwVqY6upqW7t2rWVkZFibNm1i3RwAAOARmoGhoKDALVXeti39eC0ROQ8AAEQy57W4IpeCT58+fWLdDAAA4FFr1qyx3r17x7oZCIKcBwAAIpnzWlyRSz17/oZnZmbGujkAAMAj8vPzXQHFnyXQ8pDzAABAJHNeiyty+YeuK/gQfgAAQKi4DK7lIucBAIBI5jwmrAAAAAAAAIDnUeQCAAAAAACA51HkAgAAAAAAgOe1uDm5GquqqsoqKipi3Qx4TGJiorVr1y7WzQAAAA0g5yEcyH0AEH9CKnLddtttdvvtt9e6b8CAAfbDDz+4r0tLS+3qq6+2mTNnWllZmY0aNcoee+wx6969e9ga7PP5bP369Zabmxu2bSK+dOjQwXr06MHExAAABCDnoTUi9wFAfAl5JNduu+1mH3zwwf82kPC/TYwZM8beeuste/nlly0rK8tGjx5tJ5xwgv373/8OW4P9wadbt26WlpbGCQshBefi4mLbsGGD+75nz56xbhIAAC0KOQ+tBbkPAOJTyEUuhR31htSVl5dn06ZNsxdeeMEOPfRQd98zzzxjgwYNss8//9z222+/sAxd9wefzp07N3t7iD+pqanuXwUefY4Ywg4AwP+Q89CakPsAIP6EPPH8jz/+aL169bIddtjBzjjjDFu9erW7f/78+W7uhJEjR9Y8d+DAgda3b1+bN29evdvTcPf8/Pxat/r452ZQzx7QVP7PD3N9AABQGzkPrQ25DwDiS0hFrn333ddmzJhhs2fPtscff9xWrlxpv//9762goMANL09KSnLXvQfSPA16rD4TJ050Q979tz59+myzHQxdR3Pw+QEAYGvkPLRGfJ4AIL6EdLnikUceWfP17rvv7sLQ9ttvb3//+99rhgOH6oYbbrCxY8fWfK8evsYEIAAAAIQPOQ8AAMTdnFyB1Ju3yy672PLly+0Pf/iDlZeXu7kUAnv5srOzg87t4JecnOxuzaW5IjS5ZDSHPqtHMtKrHM2aNcsWLlzY6NeMGDHChgwZYlOmTIlYO84991z3c9Z9DU32efHFF9srr7xiOTk5tmDBAtcuAADgDeS8yOa8lpz16vroo4/skEMOcZmu7mi+QNrGNddc40YBXnHFFWFtIwAAES9yFRYW2ooVK+yss86yoUOHWmJios2ZM8dOPPFE9/jSpUvdXA7Dhw+3SFLwufveyba5IHrhp3NGmo2/bkxEA5BCggJCKF577TX3c4g1XeqgSx4UijSvR5cuXULexpYtW9z7f+ONN6xt27buc/XQQw9Zenp6RNoMAAD+h5wX2Zzn9awXjDo4zzvvPPvLX/5iGRkZTdrG1KlT7b777nOXwe6xxx72yCOP2LBhw8LeVgBA65QQ6on4mGOOcUPX165da7feeqtbpeS0005zIeCCCy5wQ9I7depkmZmZ7qSt4BOOFXcaop49BZ9Oux1o6VmdLNIK87bY5sWfuv1GIvxoFJRWGFIxJ9SCjo59S6BQrKWa999//yZvQxPerlu3zt5//303WahC00UXXeRWdgIAAOFFzotOzmstWS9YUVSrGI4aNcotXtAUL730kvuMPfHEE+5yWY0E0/ZUUNXqiAAAhHXi+V9++cUFnQEDBtjJJ5/slnfWstFdu3Z1j0+ePNn++Mc/uh6+gw46yA1fV29TtCj4ZHbuFvFbUwKWVhdSr5ZO0CkpKXbggQfal19+6R7TaCdNivnOO++4nlIN6//000/d0PHAS/wqKyvdNjRMXMf++uuvt3POOceOP/74WkPYr7rqqprv+/XrZxMmTLDzzz/f9ahpFaSnnnqqVtu0HV2OoKH5GnV18803N2oFmttvv9397BV0L7nkEncZg/9yRgVf9e7qfakNoVqyZIkbDfbXv/7VhRwdL/XkzZw50wVvAAAQXuS8yOQ8L2e9uv7973+7+dr0HlXcXLRoUc3784/cOvTQQ9171X2hevDBB+3CCy90HZu77rqrK3apzdOnTw95WwCA+BRSkctfYNCJXEFI3++44441j+uEpyHGusysqKjIBZ+G5mmIJ9ddd529+uqr9uyzz9rXX39tO+20k+uZ0rHyGzdunE2aNMkVeBQg6rrnnnvs+eeft2eeecaFDE3e2tC8WH4PPPCA7b333m5erMsuu8wuvfRS1yPmp1CiSwu///57dzng008/7YJsQ3S5gtqpAPPiiy+6n7WKXqJt3HHHHda7d283Essf8hTA/D2W9d38S5VrOXIFPLXbT8uW67LFL774olHHHAAANB45L7I5z2tZL5hrr73W7UvZTsVPjfxTsUwj9/3703FQ/tN9ynXbyn7Kh6LO0vnz57u856fcp++VCwEAiPicXGgcBUEtxa1w4V+5SOFCl+FNmzbN9tlnH3efCkOa2LU+GsmkVYr+9Kc/ue8fffRRe/vtt7e5/6OOOsoFHn9PnkLN3LlzXU+t3HTTTbV6A3W5goKtAlt9tIy4etXUu7bbbru5tiv43HnnnW5ov8KULnEIDL8a7aWe4Yb4h7drHoa6w9ITEhLcEP2GlioHALTsCb6jNaE30FJynvKRn5eyXjC6hNXffhX01KH5+uuvu3znz23Kav78p1y3rUn1/Zdfbtq0yV3C2b1791qP6/sffvghpHYCAJqW89S5UlJSYk2l3+kaURxLFLmiND+VerkOOOCAmvs0Yagm0VRPnr/IFThqKdiHUSsYBU68qSKShrxXV1c3uP/AnkINH1fw0JwJgfMfPPzww66dmk9BQ+V1CWJDNBGo/lDx05wceu2aNWvcXB71feBb6jwSAIDfzjWP3neXVRRsitg+EjO62Ohrb6LQhbjJeYG8lPWCCVxkQJlORbS677FuB6VGtQEAWn7OKy0rt4Xzv7O2ZaFfzl4jI9OeePHlmBa6KHK1IO3bt4/IduuuwKPw4w9LGv6tCd51qaGG1euPDvXsaSh6uGk4un9Ien00jF7/QdQNZ6JApmH/XBoBAJGhnj0FnxN+l2FdO4T/nLQxt8he+25TRCf0Blqy1p716tLlippbqyE33niju2klbhX1VOgLpO/JfgAQ+ZyXnVNoZSsS7A8dO1unlOSQt/9rXpFNW7nJ/c1OkauV03wWurxPcyv4Rzmpx0/zGQROHNoQBRIN19ZrNNmraEi35n0InLA0VJ999plr0/jx42vu+/nnn7f5um+++cYNY0xNTXXfa2JazavQp0+fel8TyuWK6inMzc11czOoB1M+/PBDF9g0ET0AIHIUfHp2Dn2UR+MURGi7gHdzXkvMesEo7/n/cMnJybFly5bZoEGD6n1+KJcr6hgq82neV/9E+8p9+n706NFNai8AILScl5qcaH07Zlj39N/+zg9d5K4GaCyKXFHqtdMEoJqTwX+N6r333usqqVqOWwWjxtCKhRMnTnTDvgcOHOjmbVDAUG9dU+28886ul009erps8q233nJzK2yLJgdV2zXHw6pVq9wcDQogmiC0PqFcrqjAdMQRR7gVdrSyjsKitn/qqac2eVlqAACAaOe8ULSkrBeM5hTTqo8qxqloptFXgSs/NvdyxbFjx7rVJHVZpy7bnDJlipvzTKstAgAQd0WuwrwtLXY/WklHvVFnnXWWFRQUuJP3u+++ax07dmz0NjSRqCZdP/vss91w7osuusgNO9fXTXXsscfamDFjXAFJqykdffTRbllpLWndkMMOO8yFJvU06nVacnxbrwmVVhdSu7QvFc+0ZLnmkwAAAPGntee8lpb16nufV155pf34449udNkbb7zhRmCFyymnnGIbN260W265xR0H7WP27NlbTUYPAEB92vh8Pp+1IJrNX8O1NSla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69q1qzte1113XQTeEQAAiIXWmvO8nvWCUQfneeedZ3/5y18sIyMj5NdPnDjRvb8ffvjBUlNTbf/997d77rnHBgwYUPOc0tJSu/rqq23mzJlWVlZmo0aNsscee8y6d+8e5ncDAPCiVlHkUs+egs/QXQ62jlmdIr6/nLwtNn/Zx26/kQg/GgVVVVVl6enp7haKTp0i//4bY8WKFdazZ08XTppC4aa6utqefPJJ22mnnWzRokV24YUXWlFRkd1///3uOfn5+Xb44YfbyJEj7YknnrDvvvvOzj//fNfDeNFFF4X5HQEAgFhobTmvtWS9ugoLC23Dhg2u6KTOyab4+OOPXeflPvvsY5WVlXbjjTe6rPf9999b+/bt3XPGjBljb731lr388svu5zN69Gg74YQT7N///neY3xEAwIta1ZxcCj5dOnWL+K0pAUs9TerV6tatm6WkpNiBBx7oRh+JRju1adPG3nnnHRs6dKglJyfbp59+6oaOB17ip5O9tqEiTufOne3666+3c845x44//vhaQ9ivuuqqmu/79etnEyZMcMUf9aj17dvXnnrqqVpt03Z22WUXNzRfo65uvvlmq6io2OZ7uv32293oqczMTLvkkkusvLy85nJG9UquXr3avS+1IVRHHHGEPfPMMy7YqE3HHnus6+1U757f888/7/Y5ffp022233ezUU091x+fBBx8MeX8AAKBl82rO83LWq0uFpN133929x/322891Qvrfn3/k1qGHHureq+5rypUAypHKdXvssYe7KkB5cv78+TWj+qZNm+aynvajY6m8+Nlnn9nnn38e8v4AAK1PqypytWS6hO7VV1+1Z5991r7++ms3Okk9XVu2bKl5zrhx42zSpEm2ZMkSFyDq0nBtFXZ0MlfI0EimhubF8nvggQds7733dvNiXXbZZXbppZfa0qVLax5XKFGIUC/ZQw89ZE8//bRNnjy5wW3OmTPHtVMB5sUXX3TFJxW9RNu44447rHfv3rZu3bqakKcA5u+xrO+mIFMfBZvA3st58+bZQQcdVOvyRR1TvTfNGQEAANBScp7Xsl4w1157rduXf5qIY445xhXLNHLfvz8dB+U/3adct63sp3zYUPYTf/5TsUv70yh+v4EDB7rCnnIhAACt4nLFlk6X2D3++OMuXBx55JHuPoWL999/3/VGaUi2qDD0hz/8od7tPPLI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txt2r7CxdOnSbbZVw9P9wWTw4MH28ccfu/v9+928ebOdf/757usZM2aEfCyef/55u+yyy1wv4cCBA+2vf/2rVVdXu7b6e/emTJliN910kx133HG2++67ux7BtWvXMmQeAIA4Rc4j5wEAEFdFrpZOvVXqndNcB0888YQLLIceeqjtueee9tVXX9ns2bMtOzvbTj755AZfF4rx48fbAw884LafkJDgQsu2XHvttXb11Ve7ORuGDx9uxxxzjAs8ffr0sXXr1llmZqYLJ/r6lFNOca9ReGvoph7B+qintKKiwjp16uS+X7lypa1fv95GjhxZ8xz1pO677742b968kN4/AABANJDzgiPnAQCiqVVcrugVmmdAw7P97rrrLhd8NE+B3/Tp013IWLZsme2yyy5BX6eetsa6++677eCDD3Zfjxs3zk0gWlpa2uBQcPUonnjiie5rzY+gUDZt2jS77rrrrEePHq5nT2FEX/sF9jYGo8BUn+uvv9569epVE3YUfEQ9noH0vf8xAACAloScFxw5DwAQTRS5okgTbwb65ptvbO7cuUEn9dR8CP7wU/d1odAQcL+ePXu6fzds2GB9+/at9zXq1fNTr6CGwS9ZsqTB/ey0005Nat+kSZNs5syZbtg9czAAAACvIudtjZwHAIg2ilxR1L59+1rfFxYWuiHimpCzLn9QCfa6tm3b1sxp4Kdh4MEkJibWfK2eOdG8COG2rdV3zjzzzK2G4N9///0u/HzwwQe1Qpq/51BD+gOPg75vaMlrAACAWCHnkfMAALFHkSuG9tprL3v11VetX79+rietsbp27er+1VwJGgbfmGHkofj888/toIMOcl9XVlba/Pnz3dD2hoQ6jF3D8jXE/t1333U9iIG0yo4CkCYo9Yed/Px8++KLL+zSSy9t4rsCAACIHnIeOQ8AEH0UuWLo8ssvt6efftots6x5EDQh5/Lly92wbq1E065du6CvS01Ntf3228/1jikoaFi6VqgJl6lTp7r5IQYNGmSTJ0+2nJycbU5kGsowdvVo3nLLLfbCCy+44Oeff8E/eal6IrXKkOayUDv8S0trPofjjz++2e8PAAAg0sh55DwAQPS1qiJXbn6Bp/ajk7lW0tGEnIcffriVlZXZ9ttvb0cccUTNUPX6aOLSCy64wM3jMGDAANdjpm2Eg0KVbuq1U6j55z//6Za1DhdN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7969uw0ePNgmTJhgVVVVUWx5fH/2A02bNs1OPfVUa9++fQRb2vo05djvv//+7jX+odY//fSTu3zjqKOOilq74/n4l5WVbXW5ki4n+PTTTyPe3ninn0ngz0pGjRrV6N9TiG/kvNgh58UWOS92yHmxRc7zlnkxzHmttsi1adMmd+LUiTSQvl+/fn3Q1+ha6enTp9s//vEP+9vf/mbV1dXuF9Mvv/wSpVbH77HXL/xXXnnFvU6/+G+++WZ74IEH7K677opSq+P7+AfSSXjRokX2f//3fxFsZevUlGN/+umnu7kCDjzwQEtMTHRzBmjujBtvvDFKrY7v46+T7YMPPmg//vij+53//vvv22uvvWbr1q2LUqvjl34mwX5W+fn5VlJSErN2wRvIebFDzostcl7skPNii5znLetjmPNabZGrKdTDdPbZZ9uQIUPs4IMPdv8BdO3a1Z588slYN63V0y+dbt262VNPPWVDhw61U045xcaPH29PPPFErJsWd9S797vf/c6GDRsW66bEBU3IqN7sxx57zL7++mv3e+ett96yO++8M9ZNiwsPPfSQ7bzzzjZw4EBLSkqy0aNH23nnned6BgG0LuS82CHntRzkvOgi58UWOS8+JVgr1aVLF2vXrp1lZ2fXul/f9+jRo1HbULV9zz33tOXLl0eola1TU469VtrR8dbr/AYNGuQqwBqaql9KiPxnv6ioyGbOnOl6nBCdY6/e7LPOOqumR1XBUz+Hiy66yP0BwEk4ssdff+BqdRitcrR582a3Ysy4ceNshx12iFKr45d+JsF+VpmZme5SAqAh5LzYIefFFjkvdsh5sUXO85YeMcx5rfa/Kp0s1VM0Z86cWr1I+l49eY2h4ZDfffedOzEjssf+gAMOcCFTz/NbtmyZO/YEn+h99l9++WV37fqZZ54ZhZa2Pk059sXFxVsFHP8fAb/N64hofPY1X8N2221nlZWV9uqrr7q5ehBZ+pkE/qxElxE09hyN+EbOix1yXmyR82KHnBdb5DxvGR7LnOdr5UuMasnWGTNmuGUrL7roIrfEqH+56LPOOss3bty4mufffvvtbllXLS86f/5836mnnuqWGNXypIjssV+9erVb5WX06NG+pUuX+t58801ft27dfHfddVcM30X8HH+/Aw880K16gegd+1tvvdV99l988UW31O57773n23HHHX0nn3xyDN9F/Bz/zz//3Pfqq6+63/uffPKJWwGpf//+vpycnBi+C28qKCjwLViwwN0ULx588EH39c8//+we13HX8a+7tPS1117rW7JkiW/q1KlRW1oarQM5L3bIebFFzosdcl5skfNip8BDOa9VF7nkkUce8fXt29eXlJTklhzVB93v4IMP9p1zzjk131911VU1z+3evbvvqKOO8n399dcxanl8HXv57LPPfPvuu6/7xaVlpu+++25fZWVlDFoen8f/hx9+cL+wdPJF9I59RUWF77bbbnOBR39s9enTx3fZZZdx8o3S8f/oo498gwYNcr93Onfu7E7Ov/76a4xa7m1z5851v0Pq3vzHW//q+Nd9zZAhQ9zPSr/3n3nmmRi1Hl5Fzosdcl5skfNih5wXW+S82JjroZzXRv8X+fFiAAAAAAAAQOS02jm5AAAAAAAAED8ocgEAAAAAAMDzKHIBAAAAAADA8yhyAQAAAAAAwPMocgEAAAAAAMDzKHIBAAAAAADA8yhyAQAAAAAAwPMocgEAAAAAAMDzKHIBAAAAAADA8yhyAQAAAAAAwPMocgEAAAAAAMDzKHIBAAAAAADAvO7/AzRDCXhJAI09AAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 1500x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# get the RNN-only results from df_ham_original\n",
    "df_ham_original_rnn = df_ham_original[df_ham_original[\"model\"] == \"RNN\"]\n",
    "fig, axes = plt.subplots(1, 2, figsize=(15, 5))\n",
    "for bf in bf_vals:\n",
    "    axes[0].hist(df_ham_original_rnn[df_ham_original_rnn[\"bf\"] == bf][\"val_acc\"], bins=20, edgecolor=\"black\", alpha=0.5, label=f\"originalbf={bf}\")\n",
    "    axes[0].hist(df_ham_rerun_rnn[df_ham_rerun_rnn[\"bf\"] == bf][\"val_acc\"], bins=20, edgecolor=\"black\", alpha=0.5, label=f\"rerun bf={bf}\")\n",
    "axes[0].set_title(\"Validation Accuracy\")\n",
    "for bf in bf_vals:\n",
    "    axes[1].hist(df_ham_original_rnn[df_ham_original_rnn[\"bf\"] == bf][\"noiseless_val_acc\"], bins=20, edgecolor=\"black\", alpha=0.5, label=f\"original bf={bf}\")\n",
    "    axes[1].hist(df_ham_rerun_rnn[df_ham_rerun_rnn[\"bf\"] == bf][\"noiseless_val_acc\"], bins=20, edgecolor=\"black\", alpha=0.5, label=f\"rerun bf={bf}\")\n",
    "axes[1].set_title(\"Noiseless Validation Accuracy\")\n",
    "for ax in axes:\n",
    "    ax.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Exploratory analysis: HAM(n, k) for a variety of n, k with bf=0 "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": []
  }
 ],
 "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
}
