{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "2cb999d9",
   "metadata": {},
   "source": [
    "# Check Energy Conservation when Simulating with Flows"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "05022eb3",
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "bc40cdf0",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0f59294d",
   "metadata": {},
   "source": [
    "## Read Model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "2b94dc4f",
   "metadata": {},
   "outputs": [],
   "source": [
    "CHECKPOINT = \"example_checkpoint.ckpt\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "738893fd",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/srv/public/kraemea88/software/anaconda3/envs/smooth_normalizing_flows/lib/python3.9/site-packages/bgflow-0.0.0-py3.9.egg/bgflow/distribution/energy/openmm.py:215: UserWarning: It looks like you are using an OpenMMBridge with multiple workers in an ipython environment. This can behave a bit silly upon KeyboardInterrupt (e.g., kill the stdout stream). If you experience any issues, consider initializing the bridge with n_workers=1 in ipython/jupyter.\n"
     ]
    }
   ],
   "source": [
    "\n",
    "from bgforces.ala2 import Ala2Generator\n",
    "\n",
    "loaded = Ala2Generator.load_from_checkpoint(\n",
    "    CHECKPOINT\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ec592c2f",
   "metadata": {},
   "source": [
    "## Read Dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "89cd8f78",
   "metadata": {},
   "outputs": [],
   "source": [
    "from bgforces.ala2 import Ala2Data\n",
    "data = Ala2Data(batch_size=128, slice=1)\n",
    "data.prepare_data()\n",
    "data.setup()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7c129e07",
   "metadata": {},
   "source": [
    "### Extract Masses and Initial Positions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "43daa457",
   "metadata": {},
   "outputs": [],
   "source": [
    "from simtk.unit import amu\n",
    "masses = []\n",
    "\n",
    "for atom in data.dataset.system.topology.atoms():\n",
    "    masses.append(atom.element.mass.value_in_unit(amu))\n",
    "\n",
    "masses = torch.tensor(masses)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "51924394",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(torch.Size([10, 22, 3]), torch.Size([22]))"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x0=torch.tensor(data.dataset.xyz[:10])\n",
    "x0.shape, masses.shape\n",
    "# flow_potential.force(x0)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "433c6d17",
   "metadata": {},
   "source": [
    "## Define Model as the Potential for the Simulation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "b8db9932",
   "metadata": {},
   "outputs": [],
   "source": [
    "from bgforces.util import FlowPotentialWrapper\n",
    "potential = FlowPotentialWrapper(loaded.model, data.dataset.temperature)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "54254bb2",
   "metadata": {},
   "outputs": [],
   "source": [
    "# -- untoggle this to simulate with the ground truth potential instead --\n",
    "#potential = FlowPotentialWrapper(\n",
    "#    data.dataset.system.energy_model, \n",
    "#    data.dataset.temperature\n",
    "#)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e0f5f915",
   "metadata": {},
   "source": [
    "## NVT Equilibration"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "e67955e3",
   "metadata": {},
   "outputs": [],
   "source": [
    "from bgforces.util import VerletIntegrator, Simulation, LangevinIntegrator\n",
    "npt_integrator = LangevinIntegrator(potential, 0.001, masses=masses, temperature=300.)\n",
    "npt_simulation = Simulation(potential, npt_integrator, x0=torch.tensor(data.dataset.xyz[:10]), temperature=data.dataset.temperature)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "e8452777",
   "metadata": {},
   "outputs": [],
   "source": [
    "npt_simulation.step(1000)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5647b4bf",
   "metadata": {},
   "source": [
    "## NVE Simulation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "236cfc3e",
   "metadata": {},
   "outputs": [],
   "source": [
    "nve_integrator = VerletIntegrator(potential, 0.001, masses=masses)\n",
    "nve_simulation = Simulation(\n",
    "    potential, \n",
    "    nve_integrator,\n",
    "    x0=npt_simulation.x,\n",
    "    v0=npt_simulation.v\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "85ff27eb",
   "metadata": {},
   "outputs": [],
   "source": [
    "nve_simulation.step(5000)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "7cbff190",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.001"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "nve_simulation.integrator.time_step"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "ff8f2b65",
   "metadata": {},
   "outputs": [],
   "source": [
    "from matplotlib import pyplot as plt\n",
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "9ec9d464",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 216x216 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(figsize=(3,3))\n",
    "\n",
    "energies = np.array(nve_simulation.energies)\n",
    "dt = nve_simulation.report_interval * nve_simulation.integrator.time_step\n",
    "times = np.arange(len(energies))*dt\n",
    "ax.plot(times, energies[:,2,:])\n",
    "ax.set_xlim(0.0, times[-1])\n",
    "ax.set_xlabel(\"t [ps]\")\n",
    "ax.set_ylabel(\"Total Energy [kJ/mol]\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f48783e8",
   "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
}
