{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2429e561-b986-416e-a990-7f74de4a6b4d",
   "metadata": {},
   "outputs": [],
   "source": [
    "import chemiscope\n",
    "from ase.io import read, write\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "from matplotlib.colors import LogNorm"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5e2cda41-1824-4e93-b6f1-5fffed44fcac",
   "metadata": {},
   "source": [
    "### Load dihedral files"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ef565890-2681-441e-b001-3b208d6e95e2",
   "metadata": {},
   "outputs": [],
   "source": [
    "all_phis = []\n",
    "all_psis = []\n",
    "\n",
    "for i in range(10):\n",
    "    all_phis.append(np.load(f\"../../universal/ala2_ref/compiled_angles/{i}_phis.npy\")[::3])\n",
    "    all_psis.append(np.load(f\"../../universal/ala2_ref/compiled_angles/{i}_psis.npy\")[::3])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "72d98719-d931-4695-8d6d-ac77cf2d0798",
   "metadata": {},
   "outputs": [],
   "source": [
    "all_phis = np.array(all_phis).flatten()\n",
    "all_psis = np.array(all_psis).flatten()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2834b99e-a011-46b5-9e7f-0b988f62f181",
   "metadata": {},
   "source": [
    "### Omit a few randomly chosen structures to keep number of samples consistent with FlashMD"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c5117bfa-fdd8-4074-bc98-bcac0c403635",
   "metadata": {},
   "outputs": [],
   "source": [
    "np.random.seed(3434)\n",
    "idxs = np.arange(len(all_phis))\n",
    "np.random.shuffle(idxs)\n",
    "\n",
    "all_phis = np.array([all_phis[ii] for ii in idxs[:312510]])\n",
    "all_psis = np.array([all_psis[ii] for ii in idxs[:312510]])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e8ac357f-92f9-4b25-b79b-15a14146a8e5",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "orig_plot = plt.hist2d(\n",
    "    all_phis-360, all_psis,\n",
    "    bins=180, range=[[-180, 0], [-180, 180]],  cmap='plasma', norm=LogNorm(vmax=1e3, vmin=10))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "be65a942-93d3-429b-a753-24555c202281",
   "metadata": {},
   "outputs": [],
   "source": [
    "# -kbT at 450 K\n",
    "kbT = -0.89424\n",
    "\n",
    "hist = orig_plot[0]\n",
    "hist = hist / hist.sum()\n",
    "free_e = (np.rot90(np.log(hist)) * kbT) - (np.rot90(np.log(hist)) * kbT).min()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9e549ae5-b59a-4219-b409-d0513455aa31",
   "metadata": {},
   "source": [
    "### Save the free energy Ramachandran plot to be used for the main universal panel"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "79d81ac5-9fed-4a00-8973-fcf0aaff1c2a",
   "metadata": {},
   "outputs": [],
   "source": [
    "np.save(\"ref_free_e.npy\", free_e)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4b29549a-4f2e-44f7-b171-06c028ab4230",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.12.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
