{
 "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": "dbb57e11-ce4b-468c-9526-34a5913604d0",
   "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/compiled_angles/16fs_{i}_phis.npy\"))\n",
    "    all_psis.append(np.load(f\"../../universal/ala2/compiled_angles/16fs_{i}_psis.npy\"))\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": "code",
   "execution_count": null,
   "id": "e8ac357f-92f9-4b25-b79b-15a14146a8e5",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "orig_plot = plt.hist2d(\n",
    "    all_phis.flatten()-360, all_psis.flatten(),\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": "afeeb487-a454-4ff3-ab12-3640856c51a8",
   "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(\"flash16_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
}
