{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 112,
   "id": "3e54cf82",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import pandas as pd\n",
    "\n",
    "adagrad = np.array([\n",
    "    413.88, \n",
    "    np.nan, \n",
    "    np.nan, \n",
    "    np.nan,\n",
    "    -5572.18,\n",
    "    np.nan,\n",
    "    np.nan,\n",
    "    -15900,\n",
    "    -75.93,\n",
    "    np.nan,\n",
    "    -2041.90\n",
    "])\n",
    "\n",
    "adam = np.array([\n",
    "    423.58,\n",
    "    -1645.18,\n",
    "    np.nan,\n",
    "    -859.26,\n",
    "    -818.00,\n",
    "    -618.76,\n",
    "    np.nan,\n",
    "    -15936.06,\n",
    "    -29.78,\n",
    "    -1216.92,\n",
    "    -2041.90\n",
    "])\n",
    "\n",
    "saa = np.array([\n",
    "    423.55,\n",
    "   -1398.03,\n",
    "   -1381.79,\n",
    "   -786.91,\n",
    "   -818.01,\n",
    "   -557.36,\n",
    "   -582.78,\n",
    "   -15884.67,\n",
    "   -29.83,\n",
    "   -1209.46,\n",
    "   -2041.95\n",
    "])\n",
    "\n",
    "quasi_newton = np.array([\n",
    "    423.59,\n",
    "    np.nan,\n",
    "    np.nan,\n",
    "    np.nan,\n",
    "    -818.00,\n",
    "    np.nan,\n",
    "    np.nan,\n",
    "    -16099.44,\n",
    "    -29.78,\n",
    "    -1209.47,\n",
    "    -2041.90\n",
    "])\n",
    "\n",
    "models = [\n",
    "    'congress', \n",
    "    'election88', \n",
    "    'election88Exp', \n",
    "    'electric', \n",
    "    'electric-one', \n",
    "    'hepatitis', \n",
    "    'hiv-chr', \n",
    "    'irt',\n",
    "    'mesquite',\n",
    "    'radon',\n",
    "    'wells'\n",
    "]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 117,
   "id": "db439550",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1100x150 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "df = pd.DataFrame({'adagrad': adagrad,\n",
    "                   'quasi-newton': quasi_newton, \n",
    "                   'adam': adam, \n",
    "                   'saa': saa},\n",
    "                 index=models)\n",
    "\n",
    "top = 100\n",
    "#shift = df['adam']\n",
    "shift = df.max(axis=1, skipna=True)-top\n",
    "df = df.sub(shift, axis=0)\n",
    "df.fillna(0)\n",
    "ax = df.plot(kind=\"bar\", ylim=[0,top], figsize=(11,1.5), width=0.8)\n",
    "ax.legend(loc='center left', bbox_to_anchor=(1, 0.5))\n",
    "plt.xticks(rotation=45)\n",
    "plt.ylabel('Nats')\n",
    "plt.savefig('nats_comparison.pdf', bbox_inches='tight')  # 'bbox_inches' ensures the legend is not cut off\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a0779059",
   "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.9.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
