{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "os.chdir('../..')\n",
    "import ml_collections\n",
    "import yaml\n",
    "from Nbody.utils import model_path\n",
    "from Nbody.models import get_model\n",
    "import torch\n",
    "from Nbody.dataloader import get_dataset\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import matplotlib.lines as mlines"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "with open('Nbody/train.yaml') as file:\n",
    "    config = ml_collections.ConfigDict(yaml.safe_load(file))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of parameters: 16192\n",
      "GPU's available: 5\n"
     ]
    }
   ],
   "source": [
    "# load lstm_dev_SE model\n",
    "config.model = 'LSTM_DEV'\n",
    "config.param = 'SE'\n",
    "config.comment = 'best'\n",
    "config.gpu_id = '1'\n",
    "config.train = False\n",
    "#config.p = 30\n",
    "model_path(config)\n",
    "LSTM_dev_SE = get_model(config)\n",
    "LSTM_dev_SE.load_state_dict(torch.load(config.path), strict=False)\n",
    "LSTM_dev_SE=LSTM_dev_SE.to(config.device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of parameters: 16330\n",
      "GPU's available: 5\n"
     ]
    }
   ],
   "source": [
    "# load lstm model\n",
    "config.model = 'LSTM'\n",
    "config.param = 'SE'\n",
    "config.comment = 'best'\n",
    "config.train = False\n",
    "model_path(config)\n",
    "LSTM = get_model(config)\n",
    "LSTM.load_state_dict(torch.load(config.path), strict=False)\n",
    "LSTM = LSTM.to(config.device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "# load dataset\n",
    "dataloaders, test_loader = get_dataset(config)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "inputs,outputs,LSTM_dev_out,LSTM_out = [], [], [], []\n",
    "with torch.no_grad():\n",
    "    for i,(x,y) in enumerate(test_loader):\n",
    "        #print(i)\n",
    "        x = x.to(config.device)\n",
    "        inputs.append(x)\n",
    "        outputs.append(y)\n",
    "        LSTM_dev_out.append(LSTM_dev_SE(x))\n",
    "        LSTM_out.append(LSTM(x))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "inputs,outputs = torch.cat(inputs).detach().cpu().numpy(),torch.cat(outputs)\n",
    "LSTM_dev_out = torch.cat(LSTM_dev_out)\n",
    "LSTM_out = torch.cat(LSTM_out)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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yZo1a2jXrh1du3bltdde4+TJkzz33HPAH7cQOnr0KEuXLsXPzw+r1UpCQoKKsoiLtG3Ylns738trP75Gfkk+gX6BBNQLIKA0gPu63Ed0fe887SVVUy0W8Wz3drmXj379iKe+eIpg/2BCQ0L5S+RfuOq8qyrd/k3czzQPCnE3bziN4Cyz52j2/MD8OXpTfmZ9UIin8KbPQk2YPT8wf45mzw+8I8daG2IhIiIiImImapBFREREROyoQRYRERERsaMGWcTLbD28lac/f7rSTeUNw+Dpz59m6+GtbopMRMS3qB6blxpkES+TfCyZRd8uYuaOmbaibBgGM3fMZNG3i0g+luzmCEVEfIPqsXnV6ZP0RMR5U6+cSrG1mOW7lwMws8dMZu6YyfLdyxnXYRxTr5zq5ghFRHyD6rF5qUEW8TIWi4WZPWYCsHz3clthHtdhHDN7zHR4KIiIiNQe1WPz0hALES9kX5QrqBiLiNQ91WNzUoMs4oUqxrjZsx8DJyIidUP12JzUIIt4mYpiXDHG7ci4I4zrMI7lu5erKIuI1CHVY/PSGGQRLzP7i9m2YlxxGs9+DFyQXxDTuk9zb5AiIj5A9di81CCLeJmezXoC5VdPV4xxqyjKQX5BtuUiIlK7VI/NSw2yiJfp27IvfVv2rTTfYrHoSIWISB1SPTYvjUEWEREREbGjBllERERExI4aZBERERERO2qQRURERETsqEEWEREREbGjBllERERExI4aZBERERERO2qQRURERETsqEEWEREREbGjBllERERExI4aZBERERERO2qQRURERETsqEEWEREREbGjBllERERExE6Aqza0c+dOVq5cidVqJS4ujoSEBIflJSUlvPjii+zfv5/w8HAeeOABGjduDMA777zDli1b8PPz484776RLly6uCktExGeoDouIuIZLjiBbrVZWrFjB1KlTmT9/Ptu3b+fIkSMO62zZsoXQ0FBeeOEFrr/+el5//XUAjhw5QnJyMs899xzTpk1jxYoVWK1WV4QlIuIzVIdFRFzHJQ3y3r17adq0KU2aNCEgIICePXuSkpLisM6XX35Jnz59AOjRowe7d+/GMAxSUlLo2bMngYGBNG7cmKZNm7J3715XhCUi4jNUh0VEXMclDXJmZiZRUVG26aioKDIzM6tdx9/fn5CQEPLy8iq9NjIystJrRUTk9FSHRURc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\n",
      "text/plain": [
       "<Figure size 720x360 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "idx = 26150\n",
    "#input_path,output = inputs[i,...,:2], outputs[i,...]\n",
    "\n",
    "plt.style.use('ggplot')\n",
    "observed = mlines.Line2D([], [], color='black', marker='x', linestyle='None',\n",
    "                          markersize=6, label='last observed (x,y)')\n",
    "true = mlines.Line2D([], [], color='black',  markerfacecolor='none',marker='o', linestyle='None',\n",
    "                          markersize=8, label='true (x,y)')\n",
    "pred = mlines.Line2D([], [], color='black', marker='.', linestyle='None',\n",
    "                          markersize=6, label='predicted (x,y)')\n",
    "\n",
    "\n",
    "fig, axes = plt.subplots(1,2)\n",
    "fig.set_size_inches(10, 5)\n",
    "colors = ['r','b','c','g','m'] \n",
    "for i in range(5):\n",
    "    \n",
    "    axes[0].scatter(inputs[idx,-1,i,0],inputs[idx,-1,i,1],color = colors[i],marker='x',s=60)\n",
    "    axes[0].scatter(outputs[idx,i,0],outputs[idx,i,1],color = colors[i],s=90,\n",
    "                facecolors='none', edgecolors=colors[i])\n",
    "    axes[0].scatter(LSTM_out.detach().cpu().numpy()[idx,i,0],\n",
    "                LSTM_out.detach().cpu().numpy()[idx,i,1],color = colors[i],marker='.',s=60)\n",
    "axes[0].legend(handles=[observed, true, pred])\n",
    "x0,x1 = axes[0].get_xlim()\n",
    "y0,y1 = axes[0].get_ylim()\n",
    "axes[0].set_aspect(abs(x1-x0)/abs(y1-y0))\n",
    "axes[0].set_title('LSTM')\n",
    "for i in range(5):\n",
    "    \n",
    "    axes[1].scatter(inputs[idx,-1,i,0],inputs[idx,-1,i,1],color = colors[i],marker='x',label='last observed x-y',s=60)\n",
    "    axes[1].scatter(outputs[idx,i,0],outputs[idx,i,1],color = colors[i],s=90,\n",
    "                facecolors='none', edgecolors=colors[i],label='output x-y')\n",
    "    axes[1].scatter(LSTM_dev_out.detach().cpu().numpy()[idx,i,0],\n",
    "                LSTM_dev_out.detach().cpu().numpy()[idx,i,1],color = colors[i],marker='.',label='predicted x-y',s=60)\n",
    "axes[1].legend(handles=[observed, true, pred])\n",
    "x0,x1 = axes[1].get_xlim()\n",
    "y0,y1 = axes[1].get_ylim()\n",
    "axes[1].set_aspect(abs(x1-x0)/abs(y1-y0))\n",
    "#ax.grid(b=True, which='major', color='k', linestyle='--')\n",
    "axes[1].set_title('LSTM+DEV(SE(2))')\n",
    "fig.tight_layout()\n",
    "plt.show()\n",
    "fig.savefig('Nbody/notebooks/Nbody_plot.png',format='png',dpi=350)\n",
    "#fig.savefig('Nbody/notebooks/Nbody_LSTM_dev.png',format='png',dpi=350)\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "development",
   "language": "python",
   "name": "development"
  },
  "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.0"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
