{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## 2D IR-IR-Raman spectrum of liquid water\n",
    "\n",
    "This example uses the file 'dip_pol_neq_2d.converged' that contains a response function with 125 fs along t1 and t2."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import os\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib as mpl\n",
    "import scipy.ndimage\n",
    "import scipy.fft\n",
    "from matplotlib.ticker import MultipleLocator, AutoMinorLocator\n",
    "from mpl_toolkits.axes_grid1 import ImageGrid\n",
    "import matplotlib.patches as mpatches"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Define constants and parameters of the calculation."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Useful constants.\n",
    "fstoau = 41.34137  # Femtosecond to a.u.\n",
    "autocm1 = 219474.63  # a.u. (Hartree energy unit) to wavenumber\n",
    "invfstocm1 = autocm1 / fstoau  # fs^-1 to cm^-1 conversion"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Processing parameters\n",
    "dt = 1 * fstoau  # Timestep 1 fs\n",
    "nsteps = 125  # Number of steps in Rt\n",
    "npad = 1125  # Padding for FFT\n",
    "nplot = 175  # Number of frequency steps to plot.\n",
    "dw = 2 * np.pi / (nsteps + npad + 1) / dt * autocm1  # Frequency step for fft\n",
    "wmin = 0  # Minimum frequency in the plot\n",
    "wmax = nplot * dw  # Maximum frequency in the plot\n",
    "\n",
    "# Damping to avoid a hard cut off at long t_1/t_2.\n",
    "tau = 5e28\n",
    "damping = np.array(\n",
    "    [\n",
    "        [np.exp(-(((i + j) * dt / fstoau) ** 12) / tau) for i in range(nsteps + 1)]\n",
    "        for j in range(nsteps + 1)\n",
    "    ]\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Import response function and compute spectrum."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Import Rt.\n",
    "Rt = np.loadtxt(\"dip_pol_neq_2d.converged\")\n",
    "# Rt = np.gradient(RtRaw,dt,axis=0,edge_order=2)\n",
    "# Pad with zeros before Fourier transforming to obtain a smooth spectrum (reduce frequency step).\n",
    "Rt_padded = np.pad(Rt * damping, ((0, npad), (0, npad)))\n",
    "# Sine transform over first time axis (sine trasnform is equivalent to the imaginary part of the Fourier transform).\n",
    "St_partial = np.imag(scipy.fft.fft(Rt_padded, axis=0))\n",
    "# Sine transform over the second time axis.\n",
    "St_raw = np.imag(scipy.fft.fft(St_partial, axis=1))\n",
    "# Take the part of the spectrum that we want to plot, multiply by dt**2 to get the right units and scaling. We divide by 10**6 for convenience here, so the units will be [10**6 a.u.].\n",
    "St = St_raw[: nplot + 1, : nplot + 1] * dt**2 / 10**6"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Plot spectrum."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 330x260 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.rc(\"text\", usetex=True)\n",
    "plt.rc(\"font\", **{\"family\": \"serif\", \"serif\": [\"Computer Modern\"], \"size\": 8})\n",
    "plt.rcParams[\"contour.negative_linestyle\"] = \"solid\"\n",
    "plt.rcParams[\"contour.linewidth\"] = 0.01\n",
    "vmin = -0.51\n",
    "vmax = 0.51\n",
    "levels = np.arange(vmin, vmax, 0.06)\n",
    "\n",
    "fig, ax = plt.subplots(1, 1, figsize=(3.3, 2.6))\n",
    "cs = ax.contourf(\n",
    "    St.T,\n",
    "    levels=levels,\n",
    "    vmin=vmin,\n",
    "    vmax=vmax,\n",
    "    cmap=mpl.cm.bwr,\n",
    "    extend=\"both\",\n",
    "    extent=(wmin, wmax, wmin, wmax),\n",
    ")  # plots color map\n",
    "cs2 = ax.contour(\n",
    "    St.T,\n",
    "    levels=levels,\n",
    "    vmin=vmin,\n",
    "    vmax=vmax,\n",
    "    colors=\"tab:gray\",\n",
    "    extent=(wmin, wmax, wmin, wmax),\n",
    "    alpha=0.4,\n",
    ")  # plots contour lines\n",
    "ax.set_xlim([0, 4400])\n",
    "ax.set_ylim([0, 4400])\n",
    "ax.set_aspect(\"equal\", adjustable=\"box\")\n",
    "ax.set_xlabel(r\"$\\omega_1 / 2 \\pi c\\ [\\rm{cm}^{-1}]$\")\n",
    "ax.set_ylabel(r\"$\\omega_2 / 2 \\pi c\\ [\\rm{cm}^{-1}]$\")\n",
    "\n",
    "plt.show()"
   ]
  }
 ],
 "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.8.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
