{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "73e94744",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from matplotlib import pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "71cdda21",
   "metadata": {},
   "outputs": [],
   "source": [
    "spline = np.load(\"energies_spline.npy\")\n",
    "amber = np.load(\"energies_amber.npy\")\n",
    "smooth = np.load(\"energies_smooth.npy\")\n",
    "dt = 0.01"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "27aedf53",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 504x180 with 3 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, axes = plt.subplots(1,3, figsize=(7,2.5), sharey=True)\n",
    "fig.tight_layout()\n",
    "\n",
    "labels = [\"Amber Force Field\", \"Smooth\", \"Spline\"]\n",
    "for ax, energies, label in zip(axes, [amber, smooth, spline], labels):\n",
    "    times = np.arange(len(energies))*dt\n",
    "    shift = energies[0,2,:] - amber[0,2,:]\n",
    "    ax.plot(times, energies[:,2,:] - energies[:,2,:].mean(axis=0), lw=0.5, color=(0.2,0.2,0.2,0.4))\n",
    "    ax.plot(times, energies[:,2,3] - energies[:,2,3].mean(axis=0), lw=0.7, color=\"black\")            \n",
    "    ax.set_xlim(0.0, 10.)\n",
    "    ax.set_ylim(-5.0, 5.0)\n",
    "    ax.set_xlabel(\"t [ps]\")\n",
    "    ax.set_title(label)\n",
    "\n",
    "axes[0].set_ylabel(\"Total Energy [kJ/mol]\")\n",
    "\n",
    "\n",
    "ax = axes[2]\n",
    "fig.savefig(\"energy_conservation.png\", dpi=360, bbox_inches=\"tight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "3ed1af86",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<ipython-input-23-50a25693c7de>:18: UserWarning: FixedFormatter should only be used together with FixedLocator\n",
      "  ax.set_yticklabels([\"\"  for _ in ax.get_yticks()])\n",
      "<ipython-input-23-50a25693c7de>:18: UserWarning: FixedFormatter should only be used together with FixedLocator\n",
      "  ax.set_yticklabels([\"\"  for _ in ax.get_yticks()])\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x108 with 5 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, axes = plt.subplots(1,4, figsize=(8,1.5))\n",
    "#fig.tight_layout()\n",
    "\n",
    "labels = [\"Amber Force Field\", \"Smooth Flow\", \"Spline Flow\", \"Spline (Rescaled)\"]\n",
    "for ax, energies, label, letter in zip(axes, [amber, smooth, spline, spline], labels, \"abcd\"):\n",
    "    times = np.arange(len(energies))*dt\n",
    "    shift = energies[0,2,:] - amber[0,2,:]\n",
    "    if label == \"Spline (Rescaled)\":\n",
    "        ax, ax2 = ax.twinx(), ax\n",
    "        ax2.get_yaxis().set_visible(False)\n",
    "    colbg = (0.2,0.2,0.2,0.7) if \"Spline\" in label else (0.2,0.2,0.2,0.3)\n",
    "    ax.plot(times, energies[:,2,:] - energies[0,2,:], lw=0.5, color=colbg)\n",
    "    ax.plot(times, energies[:,2,6] - energies[0,2,6], lw=0.7, color=\"black\")            \n",
    "    ax.set_xlim(0.0, 5.)\n",
    "    if label != \"Spline (Rescaled)\":\n",
    "        ax.set_ylim(-5.0, 5.0)\n",
    "        if label in [\"Smooth Flow\", \"Spline Flow\"]:\n",
    "            ax.set_yticklabels([\"\"  for _ in ax.get_yticks()])\n",
    "    else:\n",
    "        ax.set_ylim(-3e8, 3e8)\n",
    "        ax.set_yticks(np.arange(-3e8,4e8,1e8))\n",
    "        tl = [f\"{i:>-2d}x$10^{8}$\" for i in range(-3,4)]\n",
    "        tl[3] = f\"{0:>-2d}\"\n",
    "        ax.set_yticklabels(tl)\n",
    "    ax.set_xlabel(\"t [ps]\")\n",
    "    ax.set_title(label)\n",
    "    ax.set_xticks([0,1,2,3,4,5])\n",
    "    ax.text(0.9, 0.1,f\"{letter})\",\n",
    "         horizontalalignment='center',\n",
    "         verticalalignment='center',\n",
    "         transform = ax.transAxes,\n",
    "         fontsize=12\n",
    "    )\n",
    "\n",
    "axes[0].set_ylabel(\"Total Energy [kJ/mol]\")\n",
    "axes[3].set_xlabel(\"t [ps]\")\n",
    "\n",
    "\n",
    "ax = axes[2]\n",
    "fig.savefig(\"md_energies.png\", dpi=360, bbox_inches=\"tight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "045ea2a0",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.005900793274243673"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "amber[:,2,:].std(axis=0).mean()/60"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "d4affab8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.007871761918067932"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "smooth[:,2,:].std(axis=0).mean()/60"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "38796741",
   "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.9.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
