{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib as mpl\n",
    "from bgflow.utils import (assert_numpy, distance_vectors, distances_from_vectors, \n",
    "                          remove_mean, IndexBatchIterator, LossReporter, as_numpy, compute_distances\n",
    ")\n",
    "from bgflow import (GaussianMCMCSampler, DiffEqFlow, BoltzmannGenerator, Energy, Sampler, \n",
    "                    MultiDoubleWellPotential, MeanFreeNormalDistribution, KernelDynamics, \n",
    "                    BlackBoxDynamics, TimeIndependentDynamics, DenseNet)\n",
    "from bgflow.bg import sampling_efficiency\n",
    "import ot as pot\n",
    "import tqdm\n",
    "from eq_ot_flow.models import EGNN_dynamics_AD2_cat\n",
    "from eq_ot_flow.utilities import superpose_points, superpose_points_batch, plot_flowpath_trajectory, plot_flowpath_trajectory_3d\n",
    "from eq_ot_flow.estimator import BruteForceEstimatorFast\n",
    "from eq_ot_flow.LJ import LennardJonesPotential\n",
    "from scipy.optimize import linear_sum_assignment\n",
    "from torchdyn.core import NeuralODE\n",
    "\n",
    "from bgmol.datasets import AImplicitUnconstrained\n",
    "import mdtraj as md\n",
    "from scipy.stats import vonmises\n",
    "from matplotlib.colors import LogNorm\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Using downloaded and verified file: /tmp/A.pdb\n"
     ]
    }
   ],
   "source": [
    "#dataset = AImplicitUnconstrained(download=True, read=True)\n",
    "dataset = AImplicitUnconstrained(read=True)\n",
    "n_particles = 22\n",
    "n_dimensions = 3\n",
    "dim = n_particles * n_dimensions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "target = dataset.get_energy_model()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "ala_traj = md.Trajectory(dataset.xyz, dataset.system.mdtraj_topology)\n",
    "\n",
    "atom_dict = {\"H\": 0, \"C\":1, \"N\":2, \"O\":3}\n",
    "atom_types = []\n",
    "for atom_name in ala_traj.topology.atoms:\n",
    "    atom_types.append(atom_name.name[0])\n",
    "atom_types = np.array([atom_dict[atom_type] for atom_type in atom_types])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Make the backbone atoms distingushiable\n",
    "atom_types[[4,6,8,14,16]] = np.arange(4, 9)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[0, 1, 0, 0, 0, 0, 0, 0, 0],\n",
       "        [1, 0, 0, 0, 0, 0, 0, 0, 0],\n",
       "        [1, 0, 0, 0, 0, 0, 0, 0, 0],\n",
       "        [1, 0, 0, 0, 0, 0, 0, 0, 0],\n",
       "        [0, 0, 0, 0, 1, 0, 0, 0, 0],\n",
       "        [0, 0, 0, 1, 0, 0, 0, 0, 0],\n",
       "        [0, 0, 0, 0, 0, 1, 0, 0, 0],\n",
       "        [1, 0, 0, 0, 0, 0, 0, 0, 0],\n",
       "        [0, 0, 0, 0, 0, 0, 1, 0, 0],\n",
       "        [1, 0, 0, 0, 0, 0, 0, 0, 0],\n",
       "        [0, 1, 0, 0, 0, 0, 0, 0, 0],\n",
       "        [1, 0, 0, 0, 0, 0, 0, 0, 0],\n",
       "        [1, 0, 0, 0, 0, 0, 0, 0, 0],\n",
       "        [1, 0, 0, 0, 0, 0, 0, 0, 0],\n",
       "        [0, 0, 0, 0, 0, 0, 0, 1, 0],\n",
       "        [0, 0, 0, 1, 0, 0, 0, 0, 0],\n",
       "        [0, 0, 0, 0, 0, 0, 0, 0, 1],\n",
       "        [1, 0, 0, 0, 0, 0, 0, 0, 0],\n",
       "        [0, 1, 0, 0, 0, 0, 0, 0, 0],\n",
       "        [1, 0, 0, 0, 0, 0, 0, 0, 0],\n",
       "        [1, 0, 0, 0, 0, 0, 0, 0, 0],\n",
       "        [1, 0, 0, 0, 0, 0, 0, 0, 0]])"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "h_initial = torch.nn.functional.one_hot(torch.tensor(atom_types))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "scaling = 10\n",
    "data_smaller = torch.from_numpy(np.load(\"data/AD2_relaxed.npy\")).float()/10\n",
    "data_smaller = remove_mean(data_smaller, n_particles, n_dimensions).reshape(-1, dim) * scaling"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([100000, 66])"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data_smaller.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(660, torch.Size([100000, 66]))"
      ]
     },
     "execution_count": 28,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "kappa = 10\n",
    "\n",
    "ala_traj = md.Trajectory(data_smaller.cpu().numpy().reshape(-1, n_particles, n_dimensions), dataset.system.mdtraj_topology)\n",
    "phi = md.compute_phi(ala_traj)[1].flatten()\n",
    "psi = md.compute_psi(ala_traj)[1].flatten()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(103005.78590610535, 99337.16249923782)"
      ]
     },
     "execution_count": 31,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "weights=150*vonmises.pdf(phi-1., kappa)+1\n",
    "pos_phi = ((phi>0) & (phi<2)) \n",
    "weights[pos_phi].sum(), weights[~pos_phi].sum()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [],
   "source": [
    "data_smaller_weighted_idx = np.random.choice(np.arange(len(data_smaller)), len(data_smaller), p=weights/weights.sum(), replace=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [],
   "source": [
    "data_smaller_weighted = data_smaller[data_smaller_weighted_idx]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [],
   "source": [
    "# now set up a prior\n",
    "prior =  MeanFreeNormalDistribution(dim, n_particles, two_event_dims=False).cuda()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Build the Boltzmann Generator\n",
    "\n",
    "net_dynamics = EGNN_dynamics_AD2_cat(n_particles=n_particles, device='cuda',  n_dimension=dim // n_particles,h_initial=h_initial, hidden_nf=64,\n",
    "    act_fn=torch.nn.SiLU(), n_layers=5, recurrent=True, tanh=True, attention=True, condition_time=True, mode='egnn_dynamics', agg='sum')\n",
    "\n",
    "\n",
    "bb_dynamics = BlackBoxDynamics(\n",
    "    dynamics_function=net_dynamics,\n",
    "    divergence_estimator=BruteForceEstimatorFast()\n",
    ")\n",
    "flow = DiffEqFlow(\n",
    "    dynamics=bb_dynamics\n",
    ")\n",
    "# having a flow and a prior, we can now define a Boltzmann Generator\n",
    "\n",
    "bg = BoltzmannGenerator(prior, flow, target).cuda()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {},
   "outputs": [],
   "source": [
    "# train with convex mixture of NLL and KL loss\n",
    "\n",
    "n_batch = 256\n",
    "batch_iter = IndexBatchIterator(len(data_smaller), n_batch)\n",
    "\n",
    "optim = torch.optim.Adam(bg.parameters(), lr=5e-4)\n",
    "\n",
    "n_epochs = 1000\n",
    "n_report_steps = 5\n",
    "\n",
    "\n",
    "reporter = LossReporter(\"NLL\")\n",
    "#val_losses = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "metadata": {},
   "outputs": [],
   "source": [
    "# start with 5e-4 for 1000\n",
    "# 5e-5 for 1000"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Note, in practice the batch reordering should not be done during training"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/storage/mi/leoma/libraries/en_flows_code/egnn/models2.py:195: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  t = torch.tensor(t).to(xs)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "epoch: 295, iter: 110/390, loss: 1.0583"
     ]
    }
   ],
   "source": [
    "sigma = 0.01\n",
    "for epoch in range(n_epochs):\n",
    "    for it, idxs in enumerate(batch_iter):\n",
    "\n",
    "        optim.zero_grad()\n",
    "        x1 = data_smaller[idxs].cuda()\n",
    "        batchsize = x1.shape[0]\n",
    "        t = torch.rand(batchsize, 1).cuda()\n",
    "        x0 = prior.sample(batchsize)\n",
    "\n",
    "        # Resample x0, x1 according to transport matrix\n",
    "        a1, b1 = pot.unif(x0.size()[0]), pot.unif(x1.size()[0])\n",
    "        M = torch.cdist(x0, x1) ** 2\n",
    "        M = M / M.max()\n",
    "        pi = pot.emd(a1, b1, M.detach().cpu().numpy())\n",
    "        # Sample random interpolations on pi\n",
    "        p = pi.flatten()\n",
    "        p = p / p.sum()\n",
    "        choices = np.random.choice(pi.shape[0] * pi.shape[1], p=p, size=batchsize)\n",
    "        i, j = np.divmod(choices, pi.shape[1])\n",
    "        x0 = x0[i]\n",
    "        x1 = x1[j]\n",
    "        # calculate regression loss\n",
    "        mu_t = x0 * (1 - t) + x1 * t\n",
    "        sigma_t = sigma\n",
    "        noise = prior.sample(batchsize)\n",
    "        x = mu_t + sigma_t * noise\n",
    "        ut = x1 - x0\n",
    "        vt = bg.flow._dynamics._dynamics._dynamics_function(t, x)\n",
    "        loss = torch.mean((vt - ut) ** 2)\n",
    "        loss.backward()\n",
    "        optim.step()\n",
    "        reporter.report(loss)\n",
    "\n",
    "        if it % n_report_steps == 0:\n",
    "            print(\"\\repoch: {0}, iter: {1}/{2}, loss: {3:.4}\".format(\n",
    "                    epoch,\n",
    "                    it,\n",
    "                    len(batch_iter),\n",
    "                    *reporter.recent(1).ravel()\n",
    "                ), end=\"\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 96,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "reporter.plot(log=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# PATH = \"models/alanine_weighted_OT_flow_matching\"\n",
    "\n",
    "\n",
    "# checkpoint = torch.load(PATH_last)\n",
    "# flow.load_state_dict(checkpoint['model_state_dict']), optim.load_state_dict(checkpoint['optimizer_state_dict'])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "metadata": {},
   "outputs": [],
   "source": [
    "# use OTD in the evaluation process\n",
    "bb_dynamics._divergence_estimator = brute_force_estimator_fast\n",
    "bg.flow._integrator_atol = 1e-5\n",
    "bg.flow._integrator_rtol = 1e-5\n",
    "flow._use_checkpoints = False\n",
    "flow._kwargs = {}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import tqdm\n",
    "\n",
    "n_samples = 200\n",
    "n_sample_batches = 500\n",
    "latent_np = np.empty(shape=(0))\n",
    "samples_np = np.empty(shape=(0))\n",
    "log_w_np = np.empty(shape=(0))\n",
    "dlogp_np = np.empty(shape=(0))\n",
    "#energies_np = np.empty(shape=(0))\n",
    "distances_x_np = np.empty(shape=(0))\n",
    "\n",
    "for i in tqdm.tqdm(range(n_sample_batches)):\n",
    "    with torch.no_grad():\n",
    "        samples, latent, dlogp = bg.sample(n_samples, with_latent=True, with_dlogp=True)\n",
    "        #latent = latent[0]\n",
    "        #log_weights = bg.log_weights_given_latent(samples, latent, dlogp).detach().cpu().numpy()\n",
    "        latent_np = np.append(latent_np, latent.detach().cpu().numpy())\n",
    "        samples_np = np.append(samples_np, samples.detach().cpu().numpy())\n",
    "        distances_x = distances_from_vectors(distance_vectors(samples.view(-1, n_particles, n_dimensions))).detach().cpu().numpy().reshape(-1)\n",
    "        distances_x_np = np.append(distances_x_np, distances_x)\n",
    "\n",
    "        #log_w_np = np.append(log_w_np, log_weights)\n",
    "        dlogp_np = np.append(dlogp_np, as_numpy(dlogp))\n",
    "        #energies = target.energy(samples/scaling).detach().cpu().numpy()\n",
    "        #energies_np = np.append(energies_np, energies)\n",
    "        \n",
    "\n",
    "latent_np = latent_np.reshape(-1, dim)\n",
    "samples_np = samples_np.reshape(-1, dim)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "metadata": {},
   "outputs": [],
   "source": [
    "latent_np = latent_np.reshape(-1, dim)\n",
    "samples_np = samples_np.reshape(-1, dim)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 92,
   "metadata": {},
   "outputs": [],
   "source": [
    "from bgflow import XTBEnergy, XTBBridge\n",
    "import openmm as mm\n",
    "atom_dict = {\"H\": 0, \"C\":1, \"N\":2, \"O\":3}\n",
    "atom_types_xtb = []\n",
    "for atom_name in ala_traj.topology.atoms:\n",
    "    atom_types_xtb.append(atom_name.name[0])\n",
    "atom_types_xtb = np.array([atom_dict[atom_type] for atom_type in atom_types_xtb])\n",
    "\n",
    "temperature = 300\n",
    "number_dict = {0: 1, 1:6, 2:7, 3:8}\n",
    "numbers = np.array([number_dict[atom_type] for atom_type in atom_types_xtb])\n",
    "target_xtb = XTBEnergy(\n",
    "    XTBBridge(numbers=numbers, temperature=temperature, solvent=\"water\"),\n",
    "    two_event_dims=False\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 100,
   "metadata": {},
   "outputs": [],
   "source": [
    "energies_np = as_numpy(target_xtb.energy(torch.from_numpy(samples_np)/scaling))\n",
    "\n",
    "latent_energies = prior.energy(torch.from_numpy(latent_np).cuda())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 105,
   "metadata": {},
   "outputs": [],
   "source": [
    "energy_offset = 34600\n",
    "energies_np += energy_offset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 106,
   "metadata": {},
   "outputs": [],
   "source": [
    "data_holdout_xtb = torch.from_numpy(np.load(\"data/AD2_relaxed_holdout.npy\")).reshape(-1, 66)\n",
    "energies_data_holdout = target_xtb.energy(data_holdout_xtb[::9]/scaling)\n",
    "energies_data_holdout += energy_offset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 112,
   "metadata": {},
   "outputs": [],
   "source": [
    "log_w_np = -as_numpy(energies_np).reshape(-1,1) + as_numpy(latent_energies) + dlogp_np.reshape(-1,1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 114,
   "metadata": {},
   "outputs": [],
   "source": [
    "energies_np = energies_np[np.isfinite(log_w_np).flatten()]\n",
    "samples_np_plot = samples_np[np.isfinite(log_w_np).flatten()]\n",
    "log_w_np = log_w_np[np.isfinite(log_w_np)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 115,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.003468569933906407"
      ]
     },
     "execution_count": 115,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "sampling_efficiency(torch.from_numpy(log_w_np)).item()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 121,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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ceNGRo0aRd++fRkxYgR58+ZNV3v69OnjHb7u69SpU2zevJnNmzczfvx4WrRowfjx4ylcuHCqsk8//TSzZ8/m+++/Z9q0abz77rs88MADqcpt376de+65B4D8+fMzduxY8ufPn6JMUlISAwcOZPjw4akCnJ07d7Jz506mTZvGsGHDmDp1KqVKlQr62p5++mleeeWVFIHl9u3b2b59O1OnTqV///5pDu0P19KlS2ndujV79uxJsf/06dMkJCSwadMmFi9ezNChQzl48CBFixZNUS4zPodAnnjiCYYOHZpin+f+mThxInPmzKFOnTrs3r2bNm3asGzZshRlV69ezZNPPsm3337LzJkzKVCgQJrX/PTTT7nnnntSBNaJiYnMmTOHOXPmMGbMGCZOnJjqs49EZtwnJ06coHPnznzzzTepjnnq+O233/jss8948803eeSRR9Ld3twi3CA5wed5wRDlfI8lBC0Vuu4jmVS3Z6j1T9baUHOdRSQLBcuGW3uNM4SweY2LzmZzRERyhd69ezN79mxWrVrFihUruOqqq1IcX7lyJb/++qu3bFbr0aOHN0hesGBBptTZs2dPFi1axBVXXEH37t2pUKECR44c4bfffvOWOXDgAA0aNGDDhg0A1KhRg86dO1OtWjWioqL4/fffiY+PZ/v27Xz00UckJSUFDLDCceLECfLly0fjxo255pprqFy5MrGxsezdu5f169fz6aefcuDAAWbMmMGdd97JlClTUtURFRXFZ599xhVXXMHBgwcZNGgQjRs3pmbNmt4yycnJ9OzZ09sj99prr1GrVq0U9Vhr6dKlC5MnTwacRGvdu3enTp06xMbGsmXLFsaPH8+yZcv4+eefadasGUuXLqVgwdR/pr/22mu8/PLLgLPUWNeuXbnpppsoUKAAv/76Kx9++CHDhw9nx45Qsx7Dc/z4cTp06OANkBs1akTr1q255JJLiIqKYt++faxevZo5c+YEnT+fGZ+Dv3feeYeJEydSsWJF7rrrLqpVq8ahQ4f49NNP+eGHHzh48CCdOnVi9erV3HrrraxYsYJWrVrRunVrLrjgAtauXcuwYcPYv38/Cxcu5KWXXuLFF18Mec2lS5d63/c+ffrQqFEjoqOjWbp0KR999BHHjh3jm2++oWfPnkycODGyN9qVWffJU0895Q2QS5cuTc+ePalZsyaFChXi6NGj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+b//+78U16pcuTJDhgzhscce4+TJk7Rs2ZKuXbty0003kT9/fn777Tc+/PBD9u3bR4cOHTI8bHfFihU8/PDDFCtWjJtvvpm6detStmxZoqKi2L17N7NmzWLmzJmAE2w9+eSTWfY5ZLdWrVrx3Xffcd1119GrVy9uuOEGoqOjWbp0KR999JE3m/Vtt93m/TIoUplxnxw+fJhnn32W559/nuuuu46GDRtSrVo14uLiOHDgAKtWreLzzz/3Dte//fbbueSSSzL+BuVwCpJFREREzjN79+4Na15zqVKl6NevH08++ST58+dPs3xmK1y4MD/88AP33HMP48eP5/jx44wePZrRo0cHPSfSBEjgBK5vv/02/fv3Jzk5me+//57vv/8+RZnLLruMqVOnpspW7Wvy5MmMHDkSgJo1a/Laa68FLPfoo48yc+ZMvvvuO2bPns3rr7/OoEGDUpSJj4+natWqvPjii5w8eZLp06d718gOJFi283//+98cPHiQV199leTkZMaOHcvYsWNTlHnooYe47bbbMhwke5ZQOnjwoHfJp0BiY2MZMWKEN4mXR2Z9DjnB1VdfTffu3bn77rv58MMP+fDD1KvTtmrVijFjxmToOhm9Tzyf2ZkzZwK+3766dOnivb/PdQqSRURERM5zMTExFClShCJFilC5cmWuuuoqrrvuOm655ZaQGYbPhri4OMaNG8fjjz/O6NGjWbBgAVu3buXw4cPkz5+f0qVLU7NmTRo1akS7du2oVKlSuq5z//33U6dOHd544w0WLlzI/v37KVasGFWqVKFTp07ce++9Ide+3bFjhzdwy5cvH59//nnQuePGGEaNGsXll1/Ovn37ePrpp7nxxhu56qqrUpR55pln6Nu3Lx9++CFz5sxh3bp1HDhwgKioKC688EKqV69OgwYNaNWqFddee23Qtr388su0atWKYcOGsWjRIvbv30+JEiWoW7cu9913Hy1btmT+/Pnpet98vffee/Tq1Yu5c+eycOFC1q9fz759+zhz5gxFixalevXq3HTTTdx9991Bv8zI6OeQk/Ts2ZMrrriCYcOGMXfuXHbu3EnBggW58sor6du3Lz169MjwNTJ6nzRq1Ih169Yxd+5c5s2bx2+//cb27ds5fvw4BQsW5JJLLuHaa6+lV69eNGrUKMPtzS2MtTa725Aj1atXz6Y1rl9E0r9Ocu1vUn67vOrWruk63zvc2s0YKiLh++OPP1KsUSoiIuk3f/58mjZtCsBzzz13VvIHSMb+LzPGLLfW1vPfr8RdIiIiIiIiIi4NtxaR9HHnpHgSaImIiIiInAvUkywiIiIiIiLiUpAsIiIiIiIi4lKQLCIiIiIiIuLSnGQRCSlY9mr/uciRZqcWEREROZc0adIErRx0blBPsoiIiIiIiIhLQbKIiIiIiIiIS0GyiIiIiIiIiEtBsoiIiIiIiIhLQbKIiIiIiIiIS0GyiIiIiIiIiEtBsoiIiIiIiIhLQbKIiIiIiIiIS0GyiIiIiIiIiEtBsoiIiIiIiIgrT3Y3QEQkI2av+RuAVd+tD3h8wE3VzmZzRERERCSXU0+yiIiIiIiIiEtBsoiIiIiIiIhLQbKIiIiIiIiIS0GyiIiIiAS0efNmjDEYY+jdu3d2N0dE5KxQ4i4RERGRbGaMCXmsUKFClClThnr16tGtWzdat259FlsXWnx8PJs3bwZg8ODB2doWkfPd5s2biY+PB6BJkyY0adIkW9uTWylIFhERkfDMeyW7W3B2NX0yu1sAgLWWhIQE1q1bx7p16xgzZgyNGzdm0qRJXHDBBdndPOLj41mwYAGgIFkku23evJnnn3/eu60gOX0UJIucr0aODKtYbXeJJREROTsmT56cYjs5OZl9+/axZMkSxo4dS2JiIgsWLKBdu3YsXLgwZC+0iIhETkGyiIiISA7Svn37gPv79evHo48+SsOGDUlISOCHH35gxowZtGzZ8uw2UETkHKfEXSIiIiK5RK1atbj77ru9255hziIiknkUJIuIiIjkItWrV/c+P3z4cMiy1lq++OILOnXqxCWXXEL+/PkpWrQol19+OY8++ih//vlnutvRpEkTjDEpAnVPJmzfh2eesm+m7HAf/hm14+Pjvcc8yYmWLVtGr169qFixIgUKFKB8+fJ0796d1atXpzj3zJkzfP7559x4442ULl2a/PnzU61aNZ544gmOHDkS8rWeOHGCyZMn8+CDD1K/fn0uuOAC8ubNS5EiRahZsyb3338/v/76a9jvme8Q+fHjx3PTTTdRqlQp8uXLR/ny5bnrrrtYu3btWasrUpMnT+bWW2/loosuIn/+/FSoUIGePXvy008/AYE/p2BOnTrFRx99RNu2bSlXrlyKe3TgwIHepHDB9O7d23stT9mZM2fSvn17Lr74YvLly0eZMmXo3Lmzt33h+P3333n00Ue58sorKV68OPny5aNs2bK0bduWMWPGkJycHPTcQFnhd+zYwdNPP83ll19OsWLFUvxseKxdu5bXXnuNtm3bUqlSJQoWLEi+fPkoXbo0LVq04N133yUxMTHgNefPn48xhqZNm3r3Pf/88wF/roKZNWsWd9xxh/facXFxVK9enfvuu4/ly5eHfL/S+5pzKg23FhFHv34Bd6/6bv1ZboiIiISyb98+7/NLLrkkaLm///6bDh06sHjx4hT7T548yapVq1i1ahXDhw/nhRde4Iknnsiy9mal4cOHM2DAAJKSkrz7tm7dytatW5k8eTJTp07llltuISEhga5duzJ9+vQU5//5558MHTqUqVOn8v3331OiRImA16lRo0bAYO3IkSOsWbOGNWvW8N577/Hkk0/y8ssvh9X2xMREunfvzpQpU1Ls37p1K/Hx8YwdO5bJkyeHNZw+M+sK5fTp09x+++1MmDAhxf4tW7awZcsWxo0bx9ChQ8NOKLds2TK6dOnCpk2bUuz3v0eHDRvGvffem2Z9ycnJPPDAA4wYMSLF/l27djFx4kS+/PJLRo4cSd++fYPWkZSUxMCBAxk+fHiqQHjnzp3s3LmTadOmMWzYMKZOnUqpUqXSbNfMmTPp3r07Bw8eDFpm9OjR9OrVK+Cx3bt3s3v3bmbOnMkbb7zBtGnTuOyyy9K8briOHj1Kjx49mDZtWqpjnoSBI0eO5KGHHuLNN98kKirtftZwXnNOpiBZREREJJdITExkzJgx3u3mzZsHLJeQkECjRo1Yv975orN06dL06dOHmjVrcvz4cb777jsmTJjA6dOnefLJJ0lOTuapp56KqC0vvvgi+/bt45lnnuH3338HUicdg396vkuWLBnwuL+hQ4eyZMkSAIoWLRq03Ndff82XX35JiRIluPvuu6lVqxYnTpzgyy+/5JtvvuHkyZN07dqVTZs20atXL6ZPn851111H586dKV26NFu2bOGdd95hy5YtrF27lgEDBvDZZ58FvNaJEycoXrw4N910E3Xq1KFs2bLkzZuXHTt2sGLFCr744gtOnz7NK6+8QsmSJXnkkUfSfJ19+vRhypQp1K1bl27dunHJJZewb98+xowZw48//sjJkyfp2bMn69at48ILLzxrdYXSr18/b4CcP39+evfuTYMGDYiO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zQsvvBC0nj179tCiRQtWrlwZsI6PP/6YCRMmZFq7Bw8ezAsvvJAqmNq7dy979+7ljz/+4Ouvv2bOnDmp3s9Tp05RsmRJTp48maregwcPcvDgQVauXMmwYcN46623ePDBB8Nq065du7j11ltTvQcrVqxgxYoVTJs2jalTp5IvXz6++uorevTowbFjx7zljh8/zqxZs5g1axZvv/02/fv3T/Oap06dokOHDqle45YtW/joo4/49NNPeffdd+nbt29YryGYzLhPli5dSuvWrdmzZ0+K/adPnyYhIYFNmzaxePFihg4dysGDBylatGiG2pyZFCSLiIiI5BKJiYmMGTPGu928efNUZb777jvv8549e56VdvnyrDkMMG/evFRB8v79+1P1QM2bN48777wzxb5Vq1Z5vxDwrdPjwIEDNGjQwNv7V6NGDTp37ky1atWIiori999/Jz4+nu3bt/PRRx+RlJREfHx8ul7TnDlzuOOOO7y9xY0bN6ZTp06ULFmSrVu38umnn7JgwQLuueeeiOrt06cPU6ZMoW7dunTr1o1LLrmEffv2MWbMGH788UdOnjxJz549WbduHRdeeKH3vBdffJF9+/bxzDPP8PvvvwOpE75BylEH4AQ+1157rfd9rV+/Pu3ataNixYqcOXOGFStWEB8fz4EDBxgyZAhRUVEBe6NPnTqVIkAuWbIkd999N7Vq1eLYsWPMmDGDSZMm0blzZ6688sqI3pNApk6dyvPPPw9AgQIF6N69O9deey3FixcnMTGR7du3s2zZshT3vq/k5GROnjxJmTJluOmmm7j88su56KKLiIqKYtu2bfz4449MmzaNpKQk+vfvT5kyZejQoUPINp0+fZpOnTqxcuVKWrVqRZs2bShevDhr167l7bffZt++fcycOZOXX36ZVq1a0bFjRwoUKMDDDz9MvXr1AJg+fTpjx47FWsujjz7KjTfeSI0aNUJe9/HHH2fKlCmUL1+ePn36cOmll3LgwAGmTJnCrFmzOHXqFPfccw8lSpSgbdu26Xi3M+c+OX78OB06dPAGyI0aNaJ169ZccsklREVFsW/fPlavXs2cOXNYt25dutqZlRQki4iIiORgycnJHDhwgCVLlvDiiy96h1P27t07VQB69OhRfvvtN+92gwYNzmpbAa655hoKFizI8ePHmTdvHo899liK456hldHR0Vx11VUsXbo0YJDs29scaOhy3759vQHykCFDeOqpp1Kt7/z444/TsWNHZs2axahRo+jWrRstWrSI6PWcPn2afv36eQPkV155hSeeeCJFmQEDBnDvvffy0UcfRVT32LFjefrppxkyZEiKLOX33XcfHTt2ZMqUKRw4cICPP/44xft4/fXXA/DWW29596WViTw5OZkuXbqwb98+oqOj+eCDD7jrrrtSlLn99tt5/PHHueWWW/jll18YMmQInTt3pmbNminK/d///Z83QL7yyiuZPXt2ijnsd999N5MmTaJr164pPsf0+uCDDwBn+sDs2bNp2LBhwHKJiYkp7n+PvHnzMn36dG655Zag2eB/++03brnlFnbv3s2gQYNo165dyPXCd+7cya5du/j0009TfRnVvXt3rrzySo4fP87//vc/Pv/8cypUqMDcuXNTjJjo2bMn1atX59lnn+X06dMMHz6cd999N+R7MWXKFJo2bcpXX32VYnTF/fffz/Dhw3nooYew1nLvvfdy4403BhyBEUpm3SfffvstO3bs8LYt1Ov66aefKFCgQETtzGqakywiIiKSg/jPK42OjqZEiRK0adOGn376iZo1a/L666/z8ccfpzp39+7dJCcnA5A/f/6I5yJnhrx583LdddcBsGjRIu/Qb4958+YBULduXW8yMc++QOV86/NYsWKFd7hpnz59eOaZZwIGNIUKFWLcuHEUKVIEgDfeeCPi1zN16lQ2btwIwC233JIqQAYneHv33XepWrVqRHXfeOONvPjii6kCt6ioKF577TXv9syZMyNut78pU6awYsUKAJ577rlUgY9HyZIlGT9+PNHR0SQnJ/O///0vxfFTp07x9ttvAxATE8MXX3wRMMlbx44dGTBgQIbbDfDXX38BULNmzaABMjj3/DXXXJNqf3R0NC1atAgaIANcfvnlvPzyy4AzVP/HH39Ms139+vULOFqjatWq3v2HDx/mr7/+YsyYMammFAD8+9//Ji4uDgjvcy5SpAjjxo0LGPz279+frl27As7vAt9RJ+HKrPvE85kBaY6wqF+/fo5bk11BsoiIiEguEhMTQ2xsbMBEN/v37/c+D2d+X5UqVQImfPJNTJQenp7fo0ePsnTp0hTHPMFv06ZNvcOot2zZkiLhku985Pr161OwYMEUdXz66afe54MGDQrZlmLFitGqVSsAvv/++4DzUkPx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Qok4SBaRLNCvX7pOW/Wd/xR9ERERERHJiIiGW4uIiIiIiIicyxQki4iIiIiIiLgUJIuIiIiIiIi4FCSLiIiIiIiIuBQki4iIiIiIiLgUJIuIiIiIiIi4FCSLiIiIiIiIuBQki4iIiIiIiLjyZHcDRETkHDDvldDHmz55dtohIiIikkHqSRYRERERERFxKUgWERERERERcSlIFhEREREREXEpSBYRERERERFxKUgWERERERERcSlIFhEREREREXEpSBYRERERERFxKUgWERERERERcSlIFhEREREREXEpSBYRERERERFx5cnuBojI+e3arSOzuwkiIiIiIl7qSRYRERERERFxKUgWERERERERcWm4tYiIZL15r4Q+3vTJs9MOERERkTSoJ1lERERERETEpSBZRERERERExKUgWURERERERMSlIFlERERERETEpSBZRERERERExKUgWURERERERMSlIFlERERERETEpXWSRUSy2OKN+0Meb1DpgrPUEhERERFJi3qSRURERERERFwKkkVERERERERcCpJFREREREREXAqSRURERERERFwKkkVERERERERcCpJFREREREREXAqSRURERERERFwKkkVERERERERcCpJFREREREREXAqSRURERERERFwKkkVERERERERcCpJFREREREREXHmyuwEiIiLMeyX08aZPnp12iIiIyHlPPckiIiIiIiIiLgXJIiIiIiIiIq6Ig2RjTJwxZrAxZpUx5qgx5rAxZqkxZqAxJiYjjTHGXGSMed0Ys84Yc8IYc8AYs9AYc7cxxoQ4r4ox5lFjzDRjzBZjzEljzDFjzHpjzEfGmLoZaZeIiIiIiIicHyKak2yMKQ/MByq4u44D+YB67uN2Y0wza+3BSBviBrIzgQvcXUeBOOB699HZGNPWWnvS77zrgEV+1SW47arqPnobY16y1j4babtERERERETk/BF2T7IxJhqYhhMg7wJustbGAgWBbjiBaR1gTKSNMMYUAb7GCZDXAldba+OAWKA/cBq4GXgzwOl5gTPAFKAzcOH/t3ff8ZZV5cHHfw+dKSBVhFBtL0XEQBBiJbyCINGxYMOIFUGT2EgMrwWsJGpEQ2yDBVQEWzIqihRFRDTIKApIk+YoiHSYGTrzvH/sdXL33XPOueece++57ff9fPbn7LLW2uuyF3fuc9baa2XmBqVe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\n",
      "text/plain": [
       "<Figure size 1152x648 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(16,9))\n",
    "\n",
    "plt.hist(as_numpy(energies_data_holdout), bins=100, alpha=0.5, density=True, label=\"MD relaxed samples\", range=(-120, 0));\n",
    "#plt.hist(energies_np, bins=100,range=(-34710, -34610) ,alpha=0.5, density=True, label=\"BG\");\n",
    "plt.hist(energies_np, bins=100,range=(-120, 0) ,alpha=0.5, density=True, label=\"Boltzmann generator\");\n",
    "plt.hist(energies_np.reshape(-1), bins=50, density=True,  range=(-120, 0), alpha=0.4, histtype='step', linewidth=4,\n",
    "         color=\"r\", label=\"BG weighted samples\", weights=np.exp(log_w_np));\n",
    "plt.xticks(fontsize=25) \n",
    "plt.yticks(fontsize=25);\n",
    "plt.legend(fontsize=30);\n",
    "plt.xlabel(r\"Energy / $k_B T$\", fontsize=45)  \n",
    "plt.title(\"Energy distribution\", fontsize=45);\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 124,
   "metadata": {},
   "outputs": [],
   "source": [
    "# carbon atoms\n",
    "carbon_pos = np.where(atom_types==1)[0]\n",
    "carbon_samples_np = samples_np_plot.reshape(-1, 22, 3)[:, carbon_pos]\n",
    "carbon_distances = np.linalg.norm(samples_np_plot.reshape(-1, 22, 3)[:, [8]] - carbon_samples_np, axis=-1)\n",
    "# likely index of c beta atom\n",
    "cb_idx = np.where(carbon_distances==carbon_distances.min(1, keepdims=True))\n",
    "\n",
    "\n",
    "def determine_chirality_batch(cartesian_coords_batch):\n",
    "    # Convert Cartesian coordinates to numpy array\n",
    "    coords_batch = np.array(cartesian_coords_batch)\n",
    "\n",
    "    # Check if the shape of the array is (n, 4, 3), where n is the number of chirality centers\n",
    "    if coords_batch.shape[-2:] != (4, 3):\n",
    "        raise ValueError(\"Input should be a batch of four 3D Cartesian coordinates\")\n",
    "\n",
    "    # Calculate the vectors from the chirality centers to the four connected atoms\n",
    "    vectors_batch = coords_batch - coords_batch[:, 0:1, :]\n",
    "    #print(vectors_batch)\n",
    "    # Calculate the normal vectors of the planes formed by the three vectors for each chirality center\n",
    "    normal_vectors_batch = np.cross(vectors_batch[:, 1, :], vectors_batch[:, 2, :])\n",
    "    #print(normal_vectors_batch)\n",
    "    # Calculate the dot products of the normal vectors and the vectors from the chirality centers to the fourth atoms\n",
    "    dot_products_batch = np.einsum('...i,...i->...', normal_vectors_batch, vectors_batch[:, 3, :])\n",
    "    #print(dot_products_batch)\n",
    "    # Determine the chirality labels based on the signs of the dot products\n",
    "    chirality_labels_batch = np.where(dot_products_batch > .000, 'L', 'D')\n",
    "\n",
    "    return chirality_labels_batch\n",
    "\n",
    "\n",
    "back_bone_samples = samples_np_plot.reshape(-1, 22, 3)[:, np.array([8,6,14])]\n",
    "cb_samples = samples_np_plot.reshape(-1, 22, 3)[cb_idx[0], carbon_pos[cb_idx[1]]][:, None, :]\n",
    "chirality = determine_chirality_batch(np.concatenate([back_bone_samples, cb_samples], axis=1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 126,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 792x648 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "samples_np_mapped = samples_np_plot.copy()\n",
    "samples_np_mapped[chirality==\"D\"] *= -1\n",
    "traj_samples3 = md.Trajectory(samples_np_mapped[energies_np.flatten()<-75].reshape(-1, 22, 3), topology=dataset.system.mdtraj_topology)\n",
    "\n",
    "phi_indices, psi_indices = [4, 6, 8, 14], [6, 8, 14, 16]\n",
    "angles = md.compute_dihedrals(traj_samples3, [phi_indices, psi_indices])\n",
    "\n",
    "\n",
    "plot_range = [-np.pi, np.pi]\n",
    "\n",
    "\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(11, 9))\n",
    "\n",
    "h, x_bins, y_bins, im = ax.hist2d(angles[:,0], angles[:,1], 100, norm=LogNorm(), range=[plot_range,plot_range],rasterized=True)\n",
    "ticks = np.array([np.exp(-6)*h.max(), np.exp(-4)*h.max(),np.exp(-2)*h.max(), h.max()])\n",
    "ax.set_xlabel(r\"$\\varphi$\", fontsize=45)\n",
    "ax.set_title(\"Ramachandran plot\", fontsize=45)\n",
    "ax.set_ylabel(r\"$\\psi$\", fontsize=45)\n",
    "ax.xaxis.set_tick_params(labelsize=25)\n",
    "ax.yaxis.set_tick_params(labelsize=25)\n",
    "cbar = fig.colorbar(im, ticks=ticks)\n",
    "cbar.ax.set_yticklabels(np.abs(-np.log(ticks/h.max())), fontsize=25)\n",
    "cbar.ax.invert_yaxis()\n",
    "cbar.ax.set_ylabel(r\"Free energy / $k_B T$\", fontsize=35)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 128,
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_fes(\n",
    "    samples: np.ndarray,\n",
    "    bw_method:  None,\n",
    "    weights: None,\n",
    "    get_DeltaF: bool = True,\n",
    "    kBT: float = 1.0,\n",
    "):\n",
    "    from scipy.stats import gaussian_kde\n",
    "    bw_method =0.18# \"scott\"\n",
    "    grid = np.linspace(samples.min(), samples.max(), 100)\n",
    "    fes = -kBT * gaussian_kde(samples, bw_method, weights).logpdf(grid)\n",
    "    fes -= fes.min()\n",
    "    #plt.plot(grid, fes)\n",
    "\n",
    "    return grid, fes"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "traj_samples4 = md.Trajectory(samples_np_mapped.reshape(-1, 22, 3), topology=dataset.system.mdtraj_topology)\n",
    "\n",
    "phi = md.compute_phi(traj_samples4)[1].flatten()\n",
    "phi_right = phi.copy()\n",
    "phi_left = phi.copy()\n",
    "phi_right[phi<0] += 2*np.pi\n",
    "phi_left[phi>np.pi/2] -= 2*np.pi"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 130,
   "metadata": {},
   "outputs": [],
   "source": [
    "npz=np.load(\"models/ad2_umbrella_sampling_means.npz\")\n",
    "xs=npz[\"xs\"]\n",
    "f_i_mean=npz[\"f_i_mean\"]\n",
    "f_i_std=npz[\"f_i_std\"]\n",
    "        \n",
    "\n",
    "#plot_fes(phi,bw_method=None, weights=np.exp(log_w_np),get_DeltaF=False)\n",
    "grid_left, fes_left = plot_fes(phi_left, bw_method=None, weights=np.exp(log_w_np), get_DeltaF=False)\n",
    "grid_right, fes_right = plot_fes(phi_right, bw_method=None, weights=np.exp(log_w_np), get_DeltaF=False)\n",
    "middle = 1.1\n",
    "idx_left = (grid_left>=-np.pi)&(grid_left<middle)\n",
    "grid_left = grid_left[idx_left]\n",
    "fes_left = fes_left[idx_left]\n",
    "idx_right = (grid_right<=np.pi)&(grid_right>middle)\n",
    "grid_right = grid_right[idx_right]\n",
    "fes_right = fes_right[idx_right]\n",
    "\n",
    "plt.figure(figsize=(16,9))\n",
    "plt.plot(xs, f_i_mean, linewidth=5)\n",
    "plt.fill_between(xs, f_i_mean - f_i_std, f_i_mean + f_i_std, alpha=0.2)\n",
    "plt.plot(np.hstack([grid_left, grid_right]), np.hstack([fes_left, fes_right]), linewidth=5, linestyle=\"--\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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.7.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
