{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fd5863fd-3aa8-4d1f-8522-1bdf49dde109",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "43383525-4369-400b-b31a-297b33c33e92",
   "metadata": {},
   "outputs": [],
   "source": [
    "## SUPPLY MSD FILES CORRESPONDING TO 500 K\n",
    "ref_msd = np.load(\"universal_processing/ref.npy\")\n",
    "f16_msd = np.load(\"universal_processing/16fs.npy\")\n",
    "f64_msd = np.load(\"universal_processing/64fs.npy\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2194f95d-ee56-4b9c-8e6c-3e474627492b",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_averages(ref_msd):\n",
    "    \n",
    "    ref_t1_x = ref_msd[:, :35, 0].mean()\n",
    "    ref_t1_y = ref_msd[:, :35, 1].mean()\n",
    "    ref_t1_z = ref_msd[:, :35, 2].mean()\n",
    "    \n",
    "    ref_t2_x = ref_msd[:, 35:70, 0].mean()\n",
    "    ref_t2_y = ref_msd[:, 35:70, 1].mean()\n",
    "    ref_t2_z = ref_msd[:, 35:70, 2].mean()\n",
    "    \n",
    "    ref_t3_x = ref_msd[:, 70:105, 0].mean()\n",
    "    ref_t3_y = ref_msd[:, 70:105, 1].mean()\n",
    "    ref_t3_z = ref_msd[:, 70:105, 2].mean()\n",
    "    \n",
    "    ref_t4_x = ref_msd[:, 105:455, 0].mean()\n",
    "    ref_t4_y = ref_msd[:, 105:455, 1].mean()\n",
    "    ref_t4_z = ref_msd[:, 105:455, 2].mean()\n",
    "    \n",
    "    ret_x = np.array([ref_t4_x, ref_t3_x, ref_t2_x, ref_t1_x])\n",
    "    ret_y = np.array([ref_t4_y, ref_t3_y, ref_t2_y, ref_t1_y])\n",
    "    ret_z = np.array([ref_t4_z, ref_t3_z, ref_t2_z, ref_t1_z])\n",
    "\n",
    "    return ret_x, ret_y, ret_z"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8cf41050-7932-424c-bffb-d3fdb575fe77",
   "metadata": {},
   "outputs": [],
   "source": [
    "ref_x, ref_y, ref_z  = get_averages(ref_msd)\n",
    "f16_x, f16_y, f16_z  = get_averages(f16_msd)\n",
    "f64_x, f64_y, f64_z  = get_averages(f64_msd)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "31275285-ca61-4e45-b0db-1af7ee63f343",
   "metadata": {},
   "outputs": [],
   "source": [
    "## SUPPLY RAMACHANDRAN FILES GENERATED WITH PROCESSING JUPYTER NOTEBOOKS\n",
    "\n",
    "ref_ram = np.load(\"universal_processing/ref_free_e.npy\")\n",
    "f8_ram = np.load(\"universal_processing/8fs_free_e.npy\")\n",
    "f16_ram = np.load(\"universal_processing/16fs_free_e.npy\")\n",
    "\n",
    "ref_ram[np.isinf(ref_ram)] = 100\n",
    "f8_ram[np.isinf(f8_ram)] = 100\n",
    "f16_ram[np.isinf(f16_ram)] = 100\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "820edf13-65ef-423f-aa68-94ae4bbf753f",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "ref_conds = np.load(\"universal_processing/ref_conds.npy\")\n",
    "f16_conds = np.load(\"universal_processing/flash16_conds.npy\")\n",
    "T = np.load(\"universal_processing/T.npy\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1a0632d2-9598-4bc0-ad53-cf1df985c72b",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.gridspec as gridspec\n",
    "\n",
    "# Create a figure with specified size (full-page length)\n",
    "fig = plt.figure(figsize=(11, 4.25), dpi=300)\n",
    "\n",
    "# Create a gridspec layout (1 row, 2 columns, with the second column spanning more space)\n",
    "gs = gridspec.GridSpec(nrows=2, ncols=9, width_ratios=[1, 0.5, 1, 0.125, 1, 0.125, 1, 0.5, 1])\n",
    "fig.subplots_adjust(wspace=0, hspace=0.4) \n",
    "\n",
    "axissize = 10\n",
    "\n",
    "\n",
    "\n",
    "# =========== ALA2 RAMACHANDRAN ===========\n",
    "# =========== Al(110) PREMELTING ===========\n",
    "ala_fig = fig.add_subplot(gs[0, 0])  # First plot on the left\n",
    "\n",
    "ala1 = fig.add_subplot(gs[0, 2])  # First plot on the left\n",
    "ala2 = fig.add_subplot(gs[0, 4])  # Second plot on the left\n",
    "ala3 = fig.add_subplot(gs[0, 6])\n",
    "alas = [ala1, ala2, ala3]\n",
    "\n",
    "for p in alas:\n",
    "    p.set_xticks([0,90,179])\n",
    "    p.set_yticks([0,45,90,135,179])\n",
    "    p.set_xticklabels([r\"$-\\pi$\", r\"$-\\pi/2$\", 0])\n",
    "    p.set_yticklabels([])\n",
    "    p.tick_params(axis='both', which='major', labelsize=8) \n",
    "\n",
    "ala_fig.axis(\"off\")\n",
    "\n",
    "vmin = 0\n",
    "vmax = 4\n",
    "inter = \"None\"\n",
    "\n",
    "ala1.imshow(ref_ram, cmap='plasma_r', vmax=vmax, vmin=vmin, interpolation=inter)\n",
    "ala1.set_ylabel(r\"$\\psi$\", fontsize=axissize)\n",
    "ala1.set_yticklabels([r\"$\\pi$\", \"\", 0, \"\", r\"$-\\pi$\"])\n",
    "ala1.text(0.975, 0.025, \"MD\\n(0.5 fs)\", transform=ala1.transAxes,\n",
    "            fontsize=8, color=\"white\", va='bottom', ha='right')\n",
    "\n",
    "ala2.imshow(f8_ram, cmap='plasma_r', vmax=vmax, vmin=vmin, interpolation=inter)\n",
    "ala2.set_xlabel(r\"$\\phi$\", fontsize=axissize)\n",
    "ala2.text(0.975, 0.025, \"FlashMD\\n(8 fs)\", transform=ala2.transAxes,\n",
    "            fontsize=8, color=\"white\", va='bottom', ha='right')\n",
    "\n",
    "ala3.imshow(f16_ram, cmap='plasma_r', vmax=vmax, vmin=vmin, interpolation=inter)\n",
    "ala3.text(0.975, 0.025, \"FlashMD\\n(16 fs)\", transform=ala3.transAxes,\n",
    "            fontsize=8, color=\"white\", va='bottom', ha='right')\n",
    "\n",
    "\n",
    "\n",
    "# =========== Al(110) PREMELTING ===========\n",
    "al_fig = fig.add_subplot(gs[1, 0])  # First plot on the left\n",
    "al1 = fig.add_subplot(gs[1, 2])  # First plot on the left\n",
    "al2 = fig.add_subplot(gs[1, 4])  # Second plot on the left\n",
    "al3 = fig.add_subplot(gs[1, 6])\n",
    "\n",
    "als = [al1, al2, al3]\n",
    "\n",
    "for p in als:\n",
    "    p.set_xlim(-0.4, 3.4)\n",
    "    p.set_ylim(0.03, 0.11)\n",
    "    p.set_xticks([0,1,2,3])\n",
    "    p.set_xticklabels(['B', '3', '2', '1'])\n",
    "    p.tick_params(axis='both', which='major', labelsize=8) \n",
    "\n",
    "al_fig.axis(\"off\")\n",
    "\n",
    "al1.plot(ref_x, \":o\", c=\"#DAB1DA\", label=\"x\", markersize=5, linewidth=1, mec=\"k\", mew=1)\n",
    "al1.plot(ref_y, \":^\", c=\"turquoise\", label=\"y\", markersize=5, linewidth=1, mec=\"k\", mew=1)\n",
    "al1.plot(ref_z, \":s\", c=\"dodgerblue\", label=\"z\", markersize=5, linewidth=1, mec=\"k\", mew=1)\n",
    "al1.set_ylabel(\"MSD [Å$^2$]\", fontsize=axissize)\n",
    "al1.text(0.05, 0.95, \"MD\\n(1 fs)\", transform=al1.transAxes,\n",
    "            fontsize=8, va='top', ha='left')\n",
    "\n",
    "al2.plot(f16_x, \":o\", c=\"#DAB1DA\", label=\"x\", markersize=5, linewidth=1, mec=\"k\", mew=1)\n",
    "al2.plot(f16_y, \":^\", c=\"turquoise\", label=\"y\", markersize=5, linewidth=1, mec=\"k\", mew=1)\n",
    "al2.plot(f16_z, \":s\", c=\"dodgerblue\", label=\"z\", markersize=5, linewidth=1, mec=\"k\", mew=1)\n",
    "al2.set_yticklabels([])\n",
    "al2.legend(fontsize=7, loc=(0.05, 0.35))\n",
    "al2.set_xlabel(\"Layer\", fontsize=axissize)\n",
    "al2.text(0.05, 0.95, \"FlashMD\\n(16 fs)\", transform=al2.transAxes,\n",
    "            fontsize=8, va='top', ha='left')\n",
    "\n",
    "al3.plot(f64_x, \":o\", c=\"#DAB1DA\", label=\"x\", markersize=5, linewidth=1, mec=\"k\", mew=1)\n",
    "al3.plot(f64_y, \":^\", c=\"turquoise\", label=\"y\", markersize=5, linewidth=1, mec=\"k\", mew=1)\n",
    "al3.plot(f64_z, \":s\", c=\"dodgerblue\", label=\"z\", markersize=5, linewidth=1, mec=\"k\", mew=1)\n",
    "al3.set_yticklabels([])\n",
    "al3.text(0.05, 0.95, \"FlashMD\\n(64 fs)\", transform=al3.transAxes,\n",
    "            fontsize=8, va='top', ha='left')\n",
    "\n",
    "\n",
    "# =========== LiPS CONDUCTIVITY ===========\n",
    "\n",
    "li_fig = fig.add_subplot(gs[0, -1])\n",
    "li_fig.axis(\"off\")\n",
    "\n",
    "li_cond = fig.add_subplot(gs[1, -1])\n",
    "\n",
    "li_cond.plot(1/T * 1000, ref_conds, \"o\", color=\"orange\", label='MD (2 fs)', markersize=5, mec=\"k\", mew=1)\n",
    "li_cond.plot(1/T * 1000, f16_conds, \"o\", color=\"lightgreen\", label='FlashMD (16 fs)', markersize=5, mec=\"k\", mew=1)\n",
    "li_cond.set_yscale(\"log\")\n",
    "# li_cond.set_xlim(0.00135, 0.00175)\n",
    "li_cond.set_ylim(1e-2, 40)\n",
    "li_cond.set_ylabel(r\"$\\sigma_{\\text{Li}}$\", fontsize=axissize)\n",
    "li_cond.set_xlabel(r\"$1000/T$ [K$^{-1}$]\", fontsize=axissize)\n",
    "li_cond.legend(fontsize=7)\n",
    "li_cond.tick_params(axis='both', which='major', labelsize=8) \n",
    "li_cond.set_xticks([1.3, 1.4, 1.5, 1.6, 1.7])\n",
    "li_cond.set_xticklabels([1.3, \"\", 1.5, \"\", 1.7])\n",
    "\n",
    "ax1_top = li_cond.twiny()\n",
    "ax1_top.set_xlabel(r\"$T$ [K]\")\n",
    "ax1_top.set_xlim(li_cond.get_xlim()) \n",
    "ax1_top.set_xticks([1.3, 1.4, 1.5, 1.6, 1.7])\n",
    "ax1_top.set_xticklabels([770, \"\", 665, \"\", 585], fontsize=8)\n",
    "\n",
    "\n",
    "# Show the plot\n",
    "plt.savefig(\"figure3_universal.pdf\", dpi=500, bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6e2d1e89-dc2e-4a15-8284-eb0a615e3339",
   "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
}
