{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "b2502fc0",
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "2e3c6762",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import torch"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "29d6816b",
   "metadata": {},
   "outputs": [],
   "source": [
    "MODEL = \"example\"\n",
    "CHECKPOINT = \"example_checkpoint.ckpt\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "ff6b790b",
   "metadata": {
    "scrolled": true
   },
   "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": [
    "from bgforces.ala2 import Ala2Generator\n",
    "\n",
    "loaded = Ala2Generator.load_from_checkpoint(\n",
    "    CHECKPOINT\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "824cb530",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "758168"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "sum( np.prod(p.shape) for p in loaded.parameters())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "82854d69",
   "metadata": {},
   "outputs": [],
   "source": [
    "from bgforces.ala2 import Ala2Data\n",
    "data = Ala2Data(batch_size=128, slice=10)\n",
    "data.prepare_data()\n",
    "data.setup()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4d8081aa",
   "metadata": {},
   "source": [
    "# Skip This if data has already been generated:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "f832a497",
   "metadata": {},
   "outputs": [],
   "source": [
    "tolist = lambda x: list(x.detach().numpy())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "220222d2",
   "metadata": {},
   "outputs": [],
   "source": [
    "from tqdm.notebook import tqdm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "46e93f15",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c3e05e78132e47eb912f2ee0882a6b78",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/100 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "class BG:\n",
    "    samples = []\n",
    "    model_energies = []\n",
    "    target_energies = []\n",
    "    model_forces = []\n",
    "    target_forces = []\n",
    "    for i in tqdm(range(100)):\n",
    "        _samples = loaded.model.sample(100)\n",
    "        samples.append(tolist(_samples))\n",
    "        model_energies.append(tolist(loaded.model.energy(_samples)[:,0]))\n",
    "        target_energies.append(tolist(loaded.model._target.energy(_samples)[:,0]))\n",
    "        model_forces.append(tolist(loaded.model.force(_samples)))\n",
    "        target_forces.append(tolist(loaded.model._target.force(_samples)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "8d06458e",
   "metadata": {},
   "outputs": [],
   "source": [
    "np.savez(\n",
    "    f\"bg_samples_{MODEL.lower()}.npz\", \n",
    "    samples=np.array(BG.samples),\n",
    "    model_energies=np.array(BG.model_energies),\n",
    "    target_energies=np.array(BG.target_energies),\n",
    "    model_forces=np.array(BG.model_forces),\n",
    "    target_forces=np.array(BG.target_forces)\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "d932e091",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9bf1c9d716d646149de1090074acb339",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/100 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "class DATA:\n",
    "    samples = []\n",
    "    model_energies = []\n",
    "    target_energies = []\n",
    "    model_forces = []\n",
    "    target_forces = []\n",
    "    for i in tqdm(range(100)):\n",
    "        _samples = data.val_xyz[100*i:100*(i+1)]\n",
    "        samples.append(tolist(_samples))\n",
    "        model_energies.append(tolist(loaded.model.energy(_samples)[:,0]))\n",
    "        target_energies.append(tolist(loaded.model._target.energy(_samples)[:,0]))\n",
    "        model_forces.append(tolist(loaded.model.force(_samples)))\n",
    "        target_forces.append(tolist(loaded.model._target.force(_samples)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "7a3486f5",
   "metadata": {},
   "outputs": [],
   "source": [
    "np.savez(\n",
    "    f\"data_samples_{MODEL.lower()}.npz\", \n",
    "    samples=np.array(DATA.samples),\n",
    "    model_energies=np.array(DATA.model_energies),\n",
    "    target_energies=np.array(DATA.target_energies),\n",
    "    model_forces=np.array(DATA.model_forces),\n",
    "    target_forces=np.array(DATA.target_forces)\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "bbac264f",
   "metadata": {},
   "source": [
    "# ... And Resume Here"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "9a42aa77",
   "metadata": {},
   "outputs": [],
   "source": [
    "data_smooth = np.load(f\"data_samples_{MODEL.lower()}.npz\")\n",
    "bg_smooth = np.load(f\"bg_samples_{MODEL.lower()}.npz\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "8dea22bd",
   "metadata": {},
   "outputs": [],
   "source": [
    "from matplotlib import pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "df06fc7c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "55.585453"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data_mse = ((data_smooth[\"model_forces\"] - data_smooth[\"target_forces\"])**2).mean()\n",
    "np.sqrt(data_mse)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "07e70668",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "139.2388"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "bg_mse = ((bg_smooth[\"model_forces\"] - bg_smooth[\"target_forces\"])**2).mean()\n",
    "np.sqrt(bg_mse)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "7342e255",
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_energies(ax, d):\n",
    "    md_energies = d[\"target_energies\"].flatten()\n",
    "    sample_energies = d[\"model_energies\"].flatten()\n",
    "    #md_energies -= md_energies.min()\n",
    "    sample_energies -= (sample_energies.min() - md_energies.min())\n",
    "\n",
    "    cut = max(np.percentile(sample_energies, 80), 20)\n",
    "\n",
    "    # y-axis on the right\n",
    "    ax2 = plt.twinx(ax)\n",
    "    ax.get_yaxis().set_visible(False)\n",
    "\n",
    "    ax2.hist(\n",
    "        sample_energies, range=(-50, cut), bins=50, \n",
    "        density=False, label=\"Target\", fc=(1.0, 0, 0, 0.6)\n",
    "    )\n",
    "    ax2.hist(\n",
    "        md_energies, range=(-50, cut), bins=50, \n",
    "        density=False, label=\"Flow\", fc=(0,0,0.8,0.2), lw=1, ec=\"black\"\n",
    "    )\n",
    "    ax2.set_ylabel(f\"Count   [#Samples / 10000]\")\n",
    "    ax2.legend()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "5e916b74",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "187.28731"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data_smooth[\"target_energies\"].min() - data_smooth[\"model_energies\"].min()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "ee0a4b45",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "189.03488"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "bg_smooth[\"target_energies\"].min() - bg_smooth[\"model_energies\"].min()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "59d6808a",
   "metadata": {},
   "outputs": [],
   "source": [
    "from bgforces.ala2.plot import plot_phi_psi"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "5c56edb7",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<ipython-input-23-117d5a2ba036>:26: MatplotlibDeprecationWarning: savefig() got unexpected keyword argument \"extra_bbox_agents\" which is no longer supported as of 3.3 and will become an error two minor releases later\n",
      "  fig.savefig(f\"{MODEL.lower()}_bg.png\", dpi=360, extra_bbox_agents=(text1, text2), bbox_inches=\"tight\")\n",
      "<ipython-input-23-117d5a2ba036>:27: MatplotlibDeprecationWarning: savefig() got unexpected keyword argument \"extra_bbox_agents\" which is no longer supported as of 3.3 and will become an error two minor releases later\n",
      "  fig.savefig(f\"{MODEL.lower()}_bg.pdf\", dpi=360, extra_bbox_agents=(text1, text2), bbox_inches=\"tight\")\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x324 with 8 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, axes = plt.subplots(2,3,figsize=(8,4.5), sharex=\"col\")\n",
    "fig.tight_layout()\n",
    "\n",
    "plot_phi_psi(axes[0,0], torch.tensor(data_smooth[\"samples\"]), data.dataset.system)\n",
    "text1 = axes[0,0].text(-6, 0, \"TEST SET (MD)\", rotation=90, fontsize=12, va=\"center\")\n",
    "plot_phi_psi(axes[1,0], torch.tensor(bg_smooth[\"samples\"]), data.dataset.system)\n",
    "text2 = axes[1,0].text(-6, 0, \"BG SAMPLES\", rotation=90, fontsize=12, va=\"center\")\n",
    "\n",
    "ax = axes[0,1]\n",
    "ax.scatter(data_smooth[\"model_forces\"], data_smooth[\"target_forces\"], s=0.1, color=\"blue\")\n",
    "ax.set_xlim(-2800., 2800.)\n",
    "ax.set_ylim(-2800., 2800.)\n",
    "ax.set_ylabel(\"Flow Forces [$k_B T$/nm]\", labelpad=-60)\n",
    "\n",
    "ax = axes[1,1]\n",
    "ax.scatter(bg_smooth[\"model_forces\"], bg_smooth[\"target_forces\"], s=0.1, color=\"red\")\n",
    "ax.set_xlim(-2800., 2800.)\n",
    "ax.set_ylim(-2800., 2800.)\n",
    "ax.set_xlabel(\"Target Forces [$k_B T$/nm]\")\n",
    "ax.set_ylabel(\"Flow Forces [$k_B T$/nm]\", labelpad=-60)\n",
    "\n",
    "plot_energies(axes[0,2], data_smooth)\n",
    "plot_energies(axes[1,2], bg_smooth)\n",
    "axes[1,2].set_xlabel(\"Energy   [$k_B T$]\")\n",
    "\n",
    "fig.savefig(f\"{MODEL.lower()}_bg.png\", dpi=360, extra_bbox_agents=(text1, text2), bbox_inches=\"tight\")\n",
    "fig.savefig(f\"{MODEL.lower()}_bg.pdf\", dpi=360, extra_bbox_agents=(text1, text2), bbox_inches=\"tight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "37b63bc7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "49acda8d",
   "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
}
