{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import pandas as pd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "geom_mean_3d = pd.read_csv(\"non-pendulum-geom-mean.csv\")\n",
    "geom_mean_pen = pd.read_csv(\"pendulum-geom-mean.csv\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "sns.set(font_scale=1.75)\n",
    "sns.set_style('whitegrid')\n",
    "#colors = [(147/255,205/255,221/255), \"#00058A\", \"#6A0078\", (96/255,74/255,123/255), \"#8E6100\"]\n",
    "colors = [\"#00abdf\", \"#00058A\", \"#6A0078\", (96/255,74/255,123/255), \"#8E6100\"]\n",
    "sns.set_palette(sns.color_palette(colors))\n",
    "\n",
    "from matplotlib import rc\n",
    "rc('text', usetex=True)\n",
    "rc('text.latex', preamble=[r'\\usepackage{sansmath}', r'\\sansmath']) #r'\\usepackage{DejaVuSans}'\n",
    "rc('font',**{'family':'sans-serif','sans-serif':['DejaVu Sans']})\n",
    "rc('xtick.major', pad=12)\n",
    "rc('ytick.major', pad=12)\n",
    "rc('grid', linewidth=1.3)\n",
    "#import matplotlib as mpl\n",
    "#mpl.rcParams['figure.dpi'] = 1000"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 0.98, 'Prediction over 100 timesteps')"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1296x288 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, axes = plt.subplots(ncols=2, figsize=(18, 4))\n",
    "\n",
    "sns.barplot(data=geom_mean_pen, x=\"Body\", y=\"Geometric Mean\",\n",
    "             ci=95, hue=\"Network\", ax=axes[0])\n",
    "axes[0].set(yscale=\"log\", ylabel=\"Geom. mean. of rel. err.\", xlabel=None,\n",
    "       title=\"2D Systems\",\n",
    "       ylim=(1e-5, 1))\n",
    "axes[0].legend().remove()\n",
    "\n",
    "sns.barplot(data=geom_mean_3d, x=\"Body\", y=\"Geometric Mean\",\n",
    "             ci=95, hue=\"Network\", ax=axes[1])\n",
    "axes[1].set(yscale=\"log\", ylabel=None, xlabel=None,\n",
    "       title=\"3D Systems\",\n",
    "       ylim=(1e-5, 1))\n",
    "axes[1].legend().remove()\n",
    "\n",
    "axes[0].tick_params(axis='y', which='major', pad=1)\n",
    "axes[1].tick_params(axis='y', which='major', pad=1)\n",
    "\n",
    "#xlabels = [f\"{system}\" for system in geom_mean_3d[\"Body\"].unique()]\n",
    "#ax.set_xticklabels(xlabels, rotation=0)\n",
    "\n",
    "handles, labels = axes[1].get_legend_handles_labels()\n",
    "fig.subplots_adjust(bottom=0.23, wspace=0.1)\n",
    "fig.legend(handles=handles, labels=labels, bbox_to_anchor=(0.2, 0., 0.5, 0.), loc=\"lower center\", ncol=len(labels), borderaxespad=0.,\n",
    "           mode=\"expand\")\n",
    "fig.suptitle(\"Prediction over 100 timesteps\")\n",
    "#fig.legend(handles=handles, labels=labels, bbox_to_anchor=(0., 0.04, 1.0, 0.1), loc=\"lower center\", ncol=len(labels), borderaxespad=0.1, mode=\"expand\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "fig.savefig(\"geom-mean.pdf\", bbox_inches=\"tight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.7.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
