{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import pickle\n",
    "\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "from collections import defaultdict\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_results(path: str) -> None:\n",
    "    with open(os.path.join(path, 'results.pkl'), 'rb') as f:\n",
    "        results = pickle.load(f)\n",
    "    momentum_error = results['momentum error']\n",
    "    traj_error = results['traj error'].reshape(-1, 2, 9)\n",
    "    # traj_error = results['traj error'].reshape(-1, 2, 9)[:, 0, :]\n",
    "\n",
    "    mean_weight = np.array([1e2, 1e3]).reshape(1, 2, 1)\n",
    "    traj_error = traj_error * mean_weight\n",
    "    return np.stack([\n",
    "        traj_error.mean(),\n",
    "        *traj_error.mean(axis=0).mean(axis=-1),\n",
    "        1e2 * results['energy error'].mean(),\n",
    "        1e4 * momentum_error\n",
    "    ])\n",
    "\n",
    "    return np.concatenate([\n",
    "        traj_error.mean(axis=0).mean(axis=-1),\n",
    "        np.array(results['energy error'].mean()).reshape(-1),\n",
    "        np.array(momentum_error).reshape(-1)\n",
    "    ])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "def filt(df: pd.DataFrame, loss: str) -> pd.DataFrame:\n",
    "    return df[df['loss'].map(lambda x: x.__contains__(loss))]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "root = 'logs'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [],
   "source": [
    "results = defaultdict(list)\n",
    "for model_name in os.listdir(root):\n",
    "    for model_hyper in os.listdir(os.path.join(root, model_name)):\n",
    "        for file in os.listdir(os.path.join(root, model_name, model_hyper)):\n",
    "            if file.__contains__('dpm3'):\n",
    "                pkl_path = os.path.join(root, model_name, model_hyper, file, 'results.pkl')\n",
    "                if not os.path.exists(pkl_path):\n",
    "                    continue\n",
    "\n",
    "                loss, model, hyper = model_hyper.split('---')[1:-1]\n",
    "                results['loss'].append(loss)\n",
    "                results['model'].append(model)\n",
    "                results['hyper'].append(int(file.split('_')[1]))\n",
    "\n",
    "                results_dict = pickle.load(open(pkl_path, 'rb'))\n",
    "                results['pred error'].append(results_dict['pred error'].mean())\n",
    "                results['motum error'].append(results_dict['motum error'])\n",
    "                results['energy error'].append(results_dict['energy error'])\n",
    "                \n",
    "\n",
    "df = pd.DataFrame(results)\n",
    "df = df.sort_values(by='pred error')\n",
    "df['motum error'] = 10.0 * df['motum error']\n",
    "df['pred error'] = 1e2 * df['pred error']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>loss</th>\n",
       "      <th>model</th>\n",
       "      <th>hyper</th>\n",
       "      <th>pred error</th>\n",
       "      <th>motum error</th>\n",
       "      <th>energy error</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>momentum_0.5</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>30</td>\n",
       "      <td>5.085840</td>\n",
       "      <td>0.333803</td>\n",
       "      <td>0.744446</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>momentum_0.5</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>100</td>\n",
       "      <td>5.086835</td>\n",
       "      <td>0.366992</td>\n",
       "      <td>0.746459</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>momentum_0.5</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>150</td>\n",
       "      <td>5.094970</td>\n",
       "      <td>0.367742</td>\n",
       "      <td>0.745945</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>momentum_0.5</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>200</td>\n",
       "      <td>5.099890</td>\n",
       "      <td>0.368727</td>\n",
       "      <td>0.744974</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>momentum_0.5</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>50</td>\n",
       "      <td>5.100348</td>\n",
       "      <td>0.362437</td>\n",
       "      <td>0.744255</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>momentum_0.5</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>70</td>\n",
       "      <td>5.107986</td>\n",
       "      <td>0.365102</td>\n",
       "      <td>0.746003</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>implicit_energy_0.1</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>100</td>\n",
       "      <td>5.156930</td>\n",
       "      <td>5.306837</td>\n",
       "      <td>1.057865</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>implicit_energy_0.1</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>30</td>\n",
       "      <td>5.159781</td>\n",
       "      <td>5.303116</td>\n",
       "      <td>1.055824</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>implicit_energy_0.1</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>150</td>\n",
       "      <td>5.163562</td>\n",
       "      <td>5.305576</td>\n",
       "      <td>1.056505</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>implicit_energy_0.1</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>200</td>\n",
       "      <td>5.171686</td>\n",
       "      <td>5.307881</td>\n",
       "      <td>1.056407</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>implicit_energy_0.1</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>50</td>\n",
       "      <td>5.171969</td>\n",
       "      <td>5.308166</td>\n",
       "      <td>1.057406</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>implicit_energy_0.1</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>70</td>\n",
       "      <td>5.173943</td>\n",
       "      <td>5.306244</td>\n",
       "      <td>1.054313</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>naive</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>30</td>\n",
       "      <td>5.184207</td>\n",
       "      <td>5.347583</td>\n",
       "      <td>1.087878</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>momentum_0.5</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>20</td>\n",
       "      <td>5.188818</td>\n",
       "      <td>0.280425</td>\n",
       "      <td>0.744480</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>naive</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>100</td>\n",
       "      <td>5.189701</td>\n",
       "      <td>5.351412</td>\n",
       "      <td>1.091070</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>naive</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>150</td>\n",
       "      <td>5.194982</td>\n",
       "      <td>5.352928</td>\n",
       "      <td>1.090348</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>naive</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>200</td>\n",
       "      <td>5.202347</td>\n",
       "      <td>5.354972</td>\n",
       "      <td>1.089518</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>naive</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>50</td>\n",
       "      <td>5.204791</td>\n",
       "      <td>5.355865</td>\n",
       "      <td>1.091467</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>naive</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>70</td>\n",
       "      <td>5.209475</td>\n",
       "      <td>5.358253</td>\n",
       "      <td>1.091564</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>momentum_0.5</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>10</td>\n",
       "      <td>5.231470</td>\n",
       "      <td>0.096984</td>\n",
       "      <td>0.730116</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>implicit_energy_0.1</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>20</td>\n",
       "      <td>5.249196</td>\n",
       "      <td>5.320653</td>\n",
       "      <td>1.054088</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>naive</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>20</td>\n",
       "      <td>5.259454</td>\n",
       "      <td>5.362472</td>\n",
       "      <td>1.088527</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>naive</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>10</td>\n",
       "      <td>5.276897</td>\n",
       "      <td>5.362671</td>\n",
       "      <td>1.087141</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>implicit_energy_0.1</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>10</td>\n",
       "      <td>5.308611</td>\n",
       "      <td>5.341468</td>\n",
       "      <td>1.055093</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                   loss     model  hyper  pred error  motum error  \\\n",
       "6          momentum_0.5  EGNN_GRU     30    5.085840     0.333803   \n",
       "5          momentum_0.5  EGNN_GRU    100    5.086835     0.366992   \n",
       "3          momentum_0.5  EGNN_GRU    150    5.094970     0.367742   \n",
       "7          momentum_0.5  EGNN_GRU    200    5.099890     0.368727   \n",
       "4          momentum_0.5  EGNN_GRU     50    5.100348     0.362437   \n",
       "0          momentum_0.5  EGNN_GRU     70    5.107986     0.365102   \n",
       "19  implicit_energy_0.1  EGNN_GRU    100    5.156930     5.306837   \n",
       "18  implicit_energy_0.1  EGNN_GRU     30    5.159781     5.303116   \n",
       "21  implicit_energy_0.1  EGNN_GRU    150    5.163562     5.305576   \n",
       "20  implicit_energy_0.1  EGNN_GRU    200    5.171686     5.307881   \n",
       "22  implicit_energy_0.1  EGNN_GRU     50    5.171969     5.308166   \n",
       "23  implicit_energy_0.1  EGNN_GRU     70    5.173943     5.306244   \n",
       "8                 naive  EGNN_GRU     30    5.184207     5.347583   \n",
       "2          momentum_0.5  EGNN_GRU     20    5.188818     0.280425   \n",
       "9                 naive  EGNN_GRU    100    5.189701     5.351412   \n",
       "11                naive  EGNN_GRU    150    5.194982     5.352928   \n",
       "12                naive  EGNN_GRU    200    5.202347     5.354972   \n",
       "15                naive  EGNN_GRU     50    5.204791     5.355865   \n",
       "10                naive  EGNN_GRU     70    5.209475     5.358253   \n",
       "1          momentum_0.5  EGNN_GRU     10    5.231470     0.096984   \n",
       "16  implicit_energy_0.1  EGNN_GRU     20    5.249196     5.320653   \n",
       "13                naive  EGNN_GRU     20    5.259454     5.362472   \n",
       "14                naive  EGNN_GRU     10    5.276897     5.362671   \n",
       "17  implicit_energy_0.1  EGNN_GRU     10    5.308611     5.341468   \n",
       "\n",
       "    energy error  \n",
       "6       0.744446  \n",
       "5       0.746459  \n",
       "3       0.745945  \n",
       "7       0.744974  \n",
       "4       0.744255  \n",
       "0       0.746003  \n",
       "19      1.057865  \n",
       "18      1.055824  \n",
       "21      1.056505  \n",
       "20      1.056407  \n",
       "22      1.057406  \n",
       "23      1.054313  \n",
       "8       1.087878  \n",
       "2       0.744480  \n",
       "9       1.091070  \n",
       "11      1.090348  \n",
       "12      1.089518  \n",
       "15      1.091467  \n",
       "10      1.091564  \n",
       "1       0.730116  \n",
       "16      1.054088  \n",
       "13      1.088527  \n",
       "14      1.087141  \n",
       "17      1.055093  "
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [],
   "source": [
    "def name_map(name: str) -> str:\n",
    "    if name.__contains__('jensen'):\n",
    "        return 'conservation of energy (reducible)'\n",
    "    elif name.__contains__('momentum'):\n",
    "        return 'conservation of momentum (linear)'\n",
    "    elif name.__contains__('implicit_energy'):\n",
    "        return 'conservation of energy (general)'\n",
    "    elif name.__contains__('naive'):\n",
    "        return 'w/o priors'\n",
    "    else:\n",
    "        print(name)\n",
    "        raise ValueError(name)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>loss</th>\n",
       "      <th>model</th>\n",
       "      <th>hyper</th>\n",
       "      <th>pred error</th>\n",
       "      <th>motum error</th>\n",
       "      <th>energy error</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>momentum_0.5</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>30</td>\n",
       "      <td>5.085840</td>\n",
       "      <td>0.333803</td>\n",
       "      <td>0.744446</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>momentum_0.5</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>100</td>\n",
       "      <td>5.086835</td>\n",
       "      <td>0.366992</td>\n",
       "      <td>0.746459</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>momentum_0.5</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>150</td>\n",
       "      <td>5.094970</td>\n",
       "      <td>0.367742</td>\n",
       "      <td>0.745945</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>momentum_0.5</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>200</td>\n",
       "      <td>5.099890</td>\n",
       "      <td>0.368727</td>\n",
       "      <td>0.744974</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>momentum_0.5</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>50</td>\n",
       "      <td>5.100348</td>\n",
       "      <td>0.362437</td>\n",
       "      <td>0.744255</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>momentum_0.5</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>70</td>\n",
       "      <td>5.107986</td>\n",
       "      <td>0.365102</td>\n",
       "      <td>0.746003</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>implicit_energy_0.1</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>100</td>\n",
       "      <td>5.156930</td>\n",
       "      <td>5.306837</td>\n",
       "      <td>1.057865</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>implicit_energy_0.1</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>30</td>\n",
       "      <td>5.159781</td>\n",
       "      <td>5.303116</td>\n",
       "      <td>1.055824</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>implicit_energy_0.1</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>150</td>\n",
       "      <td>5.163562</td>\n",
       "      <td>5.305576</td>\n",
       "      <td>1.056505</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>implicit_energy_0.1</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>200</td>\n",
       "      <td>5.171686</td>\n",
       "      <td>5.307881</td>\n",
       "      <td>1.056407</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>implicit_energy_0.1</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>50</td>\n",
       "      <td>5.171969</td>\n",
       "      <td>5.308166</td>\n",
       "      <td>1.057406</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>implicit_energy_0.1</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>70</td>\n",
       "      <td>5.173943</td>\n",
       "      <td>5.306244</td>\n",
       "      <td>1.054313</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>naive</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>30</td>\n",
       "      <td>5.184207</td>\n",
       "      <td>5.347583</td>\n",
       "      <td>1.087878</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>momentum_0.5</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>20</td>\n",
       "      <td>5.188818</td>\n",
       "      <td>0.280425</td>\n",
       "      <td>0.744480</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>naive</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>100</td>\n",
       "      <td>5.189701</td>\n",
       "      <td>5.351412</td>\n",
       "      <td>1.091070</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>naive</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>150</td>\n",
       "      <td>5.194982</td>\n",
       "      <td>5.352928</td>\n",
       "      <td>1.090348</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>naive</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>200</td>\n",
       "      <td>5.202347</td>\n",
       "      <td>5.354972</td>\n",
       "      <td>1.089518</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>naive</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>50</td>\n",
       "      <td>5.204791</td>\n",
       "      <td>5.355865</td>\n",
       "      <td>1.091467</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>naive</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>70</td>\n",
       "      <td>5.209475</td>\n",
       "      <td>5.358253</td>\n",
       "      <td>1.091564</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>momentum_0.5</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>10</td>\n",
       "      <td>5.231470</td>\n",
       "      <td>0.096984</td>\n",
       "      <td>0.730116</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>implicit_energy_0.1</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>20</td>\n",
       "      <td>5.249196</td>\n",
       "      <td>5.320653</td>\n",
       "      <td>1.054088</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>naive</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>20</td>\n",
       "      <td>5.259454</td>\n",
       "      <td>5.362472</td>\n",
       "      <td>1.088527</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>naive</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>10</td>\n",
       "      <td>5.276897</td>\n",
       "      <td>5.362671</td>\n",
       "      <td>1.087141</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>implicit_energy_0.1</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>10</td>\n",
       "      <td>5.308611</td>\n",
       "      <td>5.341468</td>\n",
       "      <td>1.055093</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                   loss     model  hyper  pred error  motum error  \\\n",
       "6          momentum_0.5  EGNN_GRU     30    5.085840     0.333803   \n",
       "5          momentum_0.5  EGNN_GRU    100    5.086835     0.366992   \n",
       "3          momentum_0.5  EGNN_GRU    150    5.094970     0.367742   \n",
       "7          momentum_0.5  EGNN_GRU    200    5.099890     0.368727   \n",
       "4          momentum_0.5  EGNN_GRU     50    5.100348     0.362437   \n",
       "0          momentum_0.5  EGNN_GRU     70    5.107986     0.365102   \n",
       "19  implicit_energy_0.1  EGNN_GRU    100    5.156930     5.306837   \n",
       "18  implicit_energy_0.1  EGNN_GRU     30    5.159781     5.303116   \n",
       "21  implicit_energy_0.1  EGNN_GRU    150    5.163562     5.305576   \n",
       "20  implicit_energy_0.1  EGNN_GRU    200    5.171686     5.307881   \n",
       "22  implicit_energy_0.1  EGNN_GRU     50    5.171969     5.308166   \n",
       "23  implicit_energy_0.1  EGNN_GRU     70    5.173943     5.306244   \n",
       "8                 naive  EGNN_GRU     30    5.184207     5.347583   \n",
       "2          momentum_0.5  EGNN_GRU     20    5.188818     0.280425   \n",
       "9                 naive  EGNN_GRU    100    5.189701     5.351412   \n",
       "11                naive  EGNN_GRU    150    5.194982     5.352928   \n",
       "12                naive  EGNN_GRU    200    5.202347     5.354972   \n",
       "15                naive  EGNN_GRU     50    5.204791     5.355865   \n",
       "10                naive  EGNN_GRU     70    5.209475     5.358253   \n",
       "1          momentum_0.5  EGNN_GRU     10    5.231470     0.096984   \n",
       "16  implicit_energy_0.1  EGNN_GRU     20    5.249196     5.320653   \n",
       "13                naive  EGNN_GRU     20    5.259454     5.362472   \n",
       "14                naive  EGNN_GRU     10    5.276897     5.362671   \n",
       "17  implicit_energy_0.1  EGNN_GRU     10    5.308611     5.341468   \n",
       "\n",
       "    energy error  \n",
       "6       0.744446  \n",
       "5       0.746459  \n",
       "3       0.745945  \n",
       "7       0.744974  \n",
       "4       0.744255  \n",
       "0       0.746003  \n",
       "19      1.057865  \n",
       "18      1.055824  \n",
       "21      1.056505  \n",
       "20      1.056407  \n",
       "22      1.057406  \n",
       "23      1.054313  \n",
       "8       1.087878  \n",
       "2       0.744480  \n",
       "9       1.091070  \n",
       "11      1.090348  \n",
       "12      1.089518  \n",
       "15      1.091467  \n",
       "10      1.091564  \n",
       "1       0.730116  \n",
       "16      1.054088  \n",
       "13      1.088527  \n",
       "14      1.087141  \n",
       "17      1.055093  "
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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XDAyMqq1NqorISGBHj164O7uTr169fQdzn0jKSmJ9evXM2rUqErLWFlZ3RE/k8LCQgCGDRvGjh07OHr0aK23eVcmZf7+/oSFhbFp0yZCQ0NJTEwkICBA0xVakYyMDKysrDAxMeGRRx7h888/p2/fvgCkpqYC4OzsrHWNs7Oz5lxF5s2bh62trebRqFGjGri72vOI379J2ZFUSmUIoxBCiLuVokBhTvUeBVnwz0ewfQHkp6uvz09XP//nI/X56talVP//ztLSUhYuXEizZs0wNTWlcePGzJ07V3P+8OHD9O7dG3Nzc+rVq8cLL7xAdna25nxZb9OiRYtwdXWlXr16vPzyyxQVFWnKfPXVV3h5eWFmZoazszODBg3San/evHk0adIEc3Nz2rRpw//+9z/N+cjISFQqFRs3bqRDhw6Ympry3XffoVKpOH78uNa9fPzxxzRt2hSAkpISxowZo6nX29ubTz/9VFM2JCSE5cuX8/vvv2vm/UdGRlY4fHH79u107twZU1NTXF1deeutt7QSw169ejFx4kSmTp2Kg4MDLi4uhISE3PR1nzVrFg0bNsTU1JS2bduyadMmzXmVSsX+/fuZNWsWKpWq0vp69erFhAkTmDRpEvb29jg7O7NkyRJycnIYPXo01tbWNGvWjI0bN2pdV517up16jxw5Qv/+/bGyssLZ2Znhw4dz+fLlar9WHh4eADzxxBOoVCrN84p6NSdNmkSvXr10jvlGa9asoU2bNjRo0KDSMjcOX6zOv4OCggImT55MgwYNsLS0xN/fn8jISM35K1euEBwcTIMGDbCwsKB169b8+OOPWu326tWLV155hUmTJuHo6EhQUBAA9vb2dO/endWrV1d5bzXhrkzK+vfvz9NPP42fnx9BQUH8+eefpKens2bNmkqvsba2JiYmhr179zJ37lxef/11rR/Y7Xj77bfJyMjQPM6dO6dTfbWtezNHrM2MSMsqYN/Za/oORwghhLg9RbnwvtvNH5+0BpUBRH9dcT3RX6vPf9K6evUVVX/I49tvv838+fOZNm0acXFxrFq1SvPhb05ODkFBQdjb27N3715+/vlntm7dyiuvvKJVx7Zt20hISGDbtm0sX76csLAwwsLCANi3bx8TJ05k1qxZxMfHs2nTJs0IIFB/cLxixQoWL17M0aNHee2113j22WfZvn27VhtvvfUW8+fP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",
      "text/plain": [
       "<Figure size 1000x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(10, 6))\n",
    "ax = plt.gca()\n",
    "\n",
    "for setting in np.unique(df['loss']):\n",
    "    subset = df[df['loss'] == setting]\n",
    "    sns.lineplot(data=subset, x='hyper', y='pred error', label=name_map(setting), marker='o')\n",
    "    \n",
    "    for i, row in subset.iterrows():\n",
    "        ax.text(row['hyper'], row['pred error'], f'{row[\"pred error\"]:.2f}', \n",
    "                ha='center', va='bottom', fontsize=10, color='black')\n",
    "    \n",
    "plt.xticks(np.sort(np.unique(df['hyper'].values.astype(int))), fontsize=15)\n",
    "plt.xlabel('total sampling steps', fontsize=20)\n",
    "plt.ylabel('dynamics errors', fontsize=20)\n",
    "save_folder = 'figs'\n",
    "os.makedirs(save_folder, exist_ok=True)\n",
    "plt.savefig(os.path.join(save_folder, 'dpm_results.pdf'), format='pdf')\n",
    "    # sns.lineplot(data=df[df['loss'] == setting], x='hyper', y='dynamics', label=name_map(setting))\n",
    "    # print(df[df['loss'] == setting])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>loss</th>\n",
       "      <th>model</th>\n",
       "      <th>hyper</th>\n",
       "      <th>pred error</th>\n",
       "      <th>motum error</th>\n",
       "      <th>energy error</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>momentum_0.5</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>30</td>\n",
       "      <td>5.085840</td>\n",
       "      <td>0.333803</td>\n",
       "      <td>0.744446</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>momentum_0.5</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>100</td>\n",
       "      <td>5.086835</td>\n",
       "      <td>0.366992</td>\n",
       "      <td>0.746459</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>momentum_0.5</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>150</td>\n",
       "      <td>5.094970</td>\n",
       "      <td>0.367742</td>\n",
       "      <td>0.745945</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>momentum_0.5</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>200</td>\n",
       "      <td>5.099890</td>\n",
       "      <td>0.368727</td>\n",
       "      <td>0.744974</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>momentum_0.5</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>50</td>\n",
       "      <td>5.100348</td>\n",
       "      <td>0.362437</td>\n",
       "      <td>0.744255</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>momentum_0.5</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>70</td>\n",
       "      <td>5.107986</td>\n",
       "      <td>0.365102</td>\n",
       "      <td>0.746003</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>implicit_energy_0.1</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>100</td>\n",
       "      <td>5.156930</td>\n",
       "      <td>5.306837</td>\n",
       "      <td>1.057865</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>implicit_energy_0.1</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>30</td>\n",
       "      <td>5.159781</td>\n",
       "      <td>5.303116</td>\n",
       "      <td>1.055824</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>implicit_energy_0.1</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>150</td>\n",
       "      <td>5.163562</td>\n",
       "      <td>5.305576</td>\n",
       "      <td>1.056505</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>implicit_energy_0.1</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>200</td>\n",
       "      <td>5.171686</td>\n",
       "      <td>5.307881</td>\n",
       "      <td>1.056407</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>implicit_energy_0.1</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>50</td>\n",
       "      <td>5.171969</td>\n",
       "      <td>5.308166</td>\n",
       "      <td>1.057406</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>implicit_energy_0.1</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>70</td>\n",
       "      <td>5.173943</td>\n",
       "      <td>5.306244</td>\n",
       "      <td>1.054313</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>naive</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>30</td>\n",
       "      <td>5.184207</td>\n",
       "      <td>5.347583</td>\n",
       "      <td>1.087878</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>momentum_0.5</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>20</td>\n",
       "      <td>5.188818</td>\n",
       "      <td>0.280425</td>\n",
       "      <td>0.744480</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>naive</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>100</td>\n",
       "      <td>5.189701</td>\n",
       "      <td>5.351412</td>\n",
       "      <td>1.091070</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>naive</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>150</td>\n",
       "      <td>5.194982</td>\n",
       "      <td>5.352928</td>\n",
       "      <td>1.090348</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>naive</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>200</td>\n",
       "      <td>5.202347</td>\n",
       "      <td>5.354972</td>\n",
       "      <td>1.089518</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>naive</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>50</td>\n",
       "      <td>5.204791</td>\n",
       "      <td>5.355865</td>\n",
       "      <td>1.091467</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>naive</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>70</td>\n",
       "      <td>5.209475</td>\n",
       "      <td>5.358253</td>\n",
       "      <td>1.091564</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>momentum_0.5</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>10</td>\n",
       "      <td>5.231470</td>\n",
       "      <td>0.096984</td>\n",
       "      <td>0.730116</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>implicit_energy_0.1</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>20</td>\n",
       "      <td>5.249196</td>\n",
       "      <td>5.320653</td>\n",
       "      <td>1.054088</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>naive</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>20</td>\n",
       "      <td>5.259454</td>\n",
       "      <td>5.362472</td>\n",
       "      <td>1.088527</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>naive</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>10</td>\n",
       "      <td>5.276897</td>\n",
       "      <td>5.362671</td>\n",
       "      <td>1.087141</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>implicit_energy_0.1</td>\n",
       "      <td>EGNN_GRU</td>\n",
       "      <td>10</td>\n",
       "      <td>5.308611</td>\n",
       "      <td>5.341468</td>\n",
       "      <td>1.055093</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                   loss     model  hyper  pred error  motum error  \\\n",
       "6          momentum_0.5  EGNN_GRU     30    5.085840     0.333803   \n",
       "5          momentum_0.5  EGNN_GRU    100    5.086835     0.366992   \n",
       "3          momentum_0.5  EGNN_GRU    150    5.094970     0.367742   \n",
       "7          momentum_0.5  EGNN_GRU    200    5.099890     0.368727   \n",
       "4          momentum_0.5  EGNN_GRU     50    5.100348     0.362437   \n",
       "0          momentum_0.5  EGNN_GRU     70    5.107986     0.365102   \n",
       "19  implicit_energy_0.1  EGNN_GRU    100    5.156930     5.306837   \n",
       "18  implicit_energy_0.1  EGNN_GRU     30    5.159781     5.303116   \n",
       "21  implicit_energy_0.1  EGNN_GRU    150    5.163562     5.305576   \n",
       "20  implicit_energy_0.1  EGNN_GRU    200    5.171686     5.307881   \n",
       "22  implicit_energy_0.1  EGNN_GRU     50    5.171969     5.308166   \n",
       "23  implicit_energy_0.1  EGNN_GRU     70    5.173943     5.306244   \n",
       "8                 naive  EGNN_GRU     30    5.184207     5.347583   \n",
       "2          momentum_0.5  EGNN_GRU     20    5.188818     0.280425   \n",
       "9                 naive  EGNN_GRU    100    5.189701     5.351412   \n",
       "11                naive  EGNN_GRU    150    5.194982     5.352928   \n",
       "12                naive  EGNN_GRU    200    5.202347     5.354972   \n",
       "15                naive  EGNN_GRU     50    5.204791     5.355865   \n",
       "10                naive  EGNN_GRU     70    5.209475     5.358253   \n",
       "1          momentum_0.5  EGNN_GRU     10    5.231470     0.096984   \n",
       "16  implicit_energy_0.1  EGNN_GRU     20    5.249196     5.320653   \n",
       "13                naive  EGNN_GRU     20    5.259454     5.362472   \n",
       "14                naive  EGNN_GRU     10    5.276897     5.362671   \n",
       "17  implicit_energy_0.1  EGNN_GRU     10    5.308611     5.341468   \n",
       "\n",
       "    energy error  \n",
       "6       0.744446  \n",
       "5       0.746459  \n",
       "3       0.745945  \n",
       "7       0.744974  \n",
       "4       0.744255  \n",
       "0       0.746003  \n",
       "19      1.057865  \n",
       "18      1.055824  \n",
       "21      1.056505  \n",
       "20      1.056407  \n",
       "22      1.057406  \n",
       "23      1.054313  \n",
       "8       1.087878  \n",
       "2       0.744480  \n",
       "9       1.091070  \n",
       "11      1.090348  \n",
       "12      1.089518  \n",
       "15      1.091467  \n",
       "10      1.091564  \n",
       "1       0.730116  \n",
       "16      1.054088  \n",
       "13      1.088527  \n",
       "14      1.087141  \n",
       "17      1.055093  "
      ]
     },
     "execution_count": 28,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "pytorch",
   "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.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
