{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/data2/haiyang/anaconda3/envs/QHBench/lib/python3.8/site-packages/_distutils_hack/__init__.py:33: UserWarning: Setuptools is replacing distutils.\n",
      "  warnings.warn(\"Setuptools is replacing distutils.\")\n",
      "/data5/haiyang/equi/AIRS/OpenDFT/QHBench/QH9/test_dft_acceleration.py:267: UserWarning: \n",
      "The version_base parameter is not specified.\n",
      "Please specify a compatability version level, or None.\n",
      "Will assume defaults for version 1.1\n",
      "  @hydra.main(config_path='config', config_name='config')\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "NUM_THREADS = 6\n",
    "os.environ['OMP_NUM_THREADS'] = str(NUM_THREADS)\n",
    "os.environ['MKL_NUM_THREADS'] = str(NUM_THREADS)\n",
    "os.environ['NUMEXPR_NUM_THREADS'] = str(NUM_THREADS)\n",
    "os.environ[\"OPENBLAS_NUM_THREADS\"] = str(NUM_THREADS)\n",
    "os.environ[\"VECLIB_MAXIMUM_THREADS\"] = str(NUM_THREADS)\n",
    "\n",
    "import pyscf\n",
    "from pyscf import dft\n",
    "\n",
    "import sys\n",
    "sys.path.insert(0, os.path.dirname(os.getcwd()))\n",
    "\n",
    "from datasets import QH9Stable, QH9Dynamic\n",
    "from test_dft_acceleration import matrix_transform\n",
    "# dataset = QH9Stable(root='datasets')  # 2.2.1\n",
    "dataset = QH9Dynamic(root=os.path.join(os.sep.join(os.getcwd().split(os.sep)[:-1]), 'datasets'), version='300k')\n",
    "from torch.utils.data import DataLoader, Dataset\n",
    "import numpy as np\n",
    "import torch\n",
    "from torch_cluster import radius_graph\n",
    "\n",
    "import numpy as np\n",
    "import torch\n",
    "\n",
    "BOHR2ANG = 1.8897259886\n",
    "\n",
    "\n",
    "def get_orbital_mask(atom_idx):\n",
    "    idx_1s_2s = torch.tensor([0, 1])\n",
    "    idx_2p = torch.tensor([3, 4, 5])\n",
    "    orbital_mask_line1 = torch.cat([idx_1s_2s, idx_2p])\n",
    "    orbital_mask_line2 = torch.arange(14)\n",
    "    orbital_mask = orbital_mask_line1 if atom_idx <= 2 else orbital_mask_line2\n",
    "    return orbital_mask\n",
    "\n",
    "\n",
    "def build_final_matrix(data, diagonal_matrix, non_diagonal_matrix):\n",
    "    final_matrix = []\n",
    "    matrix_block_col = []\n",
    "    non_diagonal_idx = 0\n",
    "    for src_idx in range(data.atoms.shape[0]):\n",
    "        matrix_col = []\n",
    "        for dst_idx in range(data.atoms.shape[0]):\n",
    "            if src_idx == dst_idx:\n",
    "                matrix_col.append(diagonal_matrix[src_idx].index_select(\n",
    "                    -2, get_orbital_mask(data.atoms[dst_idx].item())).index_select(\n",
    "                    -1, get_orbital_mask(data.atoms[src_idx].item())\n",
    "                ))\n",
    "            else:\n",
    "                matrix_col.append(\n",
    "                    non_diagonal_matrix[non_diagonal_idx].index_select(\n",
    "                        -2, get_orbital_mask(data.atoms[dst_idx].item())).index_select(\n",
    "                        -1, get_orbital_mask(data.atoms[src_idx].item())))\n",
    "                non_diagonal_idx = non_diagonal_idx + 1\n",
    "\n",
    "        matrix_block_col.append(torch.cat(matrix_col, dim=-2))\n",
    "    final_matrix.append(torch.cat(matrix_block_col, dim=-1))\n",
    "    final_matrix = torch.stack(final_matrix, dim=0)\n",
    "    return final_matrix\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Check the MAE error between the dataset hamiltonian and the results from PySCF "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "the error is 1.018103904274355e-07\n",
      "the error is 1.0398874702355039e-07\n",
      "the error is 1.040262286925233e-07\n",
      "the error is 1.0642375272646404e-07\n",
      "the error is 1.1464225544930597e-07\n",
      "the error is 1.3952326930706611e-07\n",
      "the error is 1.738399162366277e-07\n",
      "the error is 1.7563097677604167e-07\n",
      "the error is 1.42459335964232e-07\n",
      "the error is 2.0054334540942894e-07\n"
     ]
    }
   ],
   "source": [
    "check_hamil = False\n",
    "hamils = []\n",
    "shapes = []\n",
    "start_id = 0\n",
    "for i in range(start_id, start_id + 10):\n",
    "    data = dataset[i]\n",
    "    data.atoms = data.atoms.squeeze()\n",
    "    H_data = build_final_matrix(data, data.diagonal_hamiltonian, data.non_diagonal_hamiltonian)\n",
    "    atoms = dataset[i].atoms.cpu().squeeze().numpy()\n",
    "\n",
    "    # H1 = H\n",
    "    hamiltonian_pyscf = matrix_transform(H_data, atoms, convention='back2pyscf')\n",
    "    ptable = {1:\"H\", 2:\"He\", 3:\"Li\", 4:\"Be\", 5:\"B\", 6:\"C\", 7:\"N\", 8:\"O\", 9:\"F\"}\n",
    "\n",
    "    # produce pyscf string\n",
    "    data.pos = data.pos\n",
    "\n",
    "    # pyscf\n",
    "    t = [[data.atoms[atom_idx].cpu().item(), data.pos[atom_idx].cpu().numpy()]\n",
    "         for atom_idx in range(data.num_nodes)]\n",
    "\n",
    "    data_m = pyscf.gto.Mole()\n",
    "    data_m.build(verbose=0, atom=t, basis='def2svp', unit='ang')\n",
    "\n",
    "    mf_hf_data = dft.RKS(data_m)\n",
    "    mf_hf_data.xc = 'b3lyp'\n",
    "    mf_hf_data.basis = 'def2svp'\n",
    "    mf_hf_data.kernel()\n",
    "    H_scf_H = mf_hf_data.get_fock()\n",
    "    print(f\"the error is {np.abs(hamiltonian_pyscf - H_scf_H).mean()}\")\n",
    "\n",
    "    m = pyscf.gto.Mole()\n",
    "    m.build(verbose=3, atom=t, basis='def2svp', unit='ang')\n",
    "    m.build()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Check the MAE of the Hamiltonian Matrix\n",
    "\n",
    "The x-axis denotes molecule index, and y-axis denotes the MAE on Hamiltonian matrix of MD simluations structures and the inital structures.  \n",
    "We can find that here is a distinctive MAE difference on Hamiltonian matrix between the MD structures and the inital strcutres."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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73//e7z22mtISkoSbieRITQikto555yjnX322YHbbrdbS05O1m644YbAfZWVlRoAraSkRNM0Tfv5z3+unXbaaZrX6w3EFBUVaSkpKZrH4wk875133qlpmqaVlZVpFotFO3bsWNDv/s53vqPdd999mqZp2rXXXqvNmzevx3YWFhZqjz32WNB9kydP1tasWRO4DUDbtGmTpmma9sorr3Rro8vl0hITE7W///3vIX/H//3f/2kAtPr6+qD7zznnHG3q1Kk9ts3vrbfe0oYOHdrj891yyy3abbfdFvQzH330kWY2m7XW1lbt888/1wBoH3zwgXD7mpqatPj4eO21114L3NfW1qYVFBRov/nNb4J+7t133w16vg0bNmhDhgzRnE6npmmatnPnTs1kMmmlpaU9vsau7wMA7Ze//GVQewBof/3rXzVN07T77rtPmzhxYtBz3HPPPX36u2iaptXV1WnDhw/Xli5dquXm5moPPvhgj20kkglrhIiiwJlnnhn4b4vFgqFDh+KMM84I3JebmwsAOH78OADg4MGDmDNnDkwmUyBm3rx5aGpqwtGjRzFy5Mig59+3bx88Hg9OPfXUoPtdLheGDh0KwNcjdNVVV0XsNe3ZswdfffUVUlNTg+53Op34+uuv+/x806dP73bfP/7xDzz00EM4dOgQHA4H3G43nE4nWlpaQvZU7NmzB3v37sVrr70WuE/TNHi9XpSWlmLfvn2wWCw455xzhNv19ddfo729HfPmzQvcFx8fj1mzZuHgwYNBsTNmzAi6fdlll2H58uXYtGkTrrnmGrz00ks477zzMGrUKOHfDwR/fpKTk5GWlhb0WTnrrLOC4ufMmRN0O9zfZcKECRgyZAief/55zJ8/H3Pnzu3Wq0QkKyZCRFEgPj4+6LbJZAq6z5/w9FQ3Ek5TUxMsFgt27twJi8US9FhKSgoAIDExsdfnMJvN0DQt6L729vZef+f06dODTq5+/Sn4TU5ODrr9zTff4Pvf/z6WLl2KBx98EJmZmdiyZQtuueUWtLW1hUyEmpqacPvtt2PVqlXdHhs5ciS++uqrPrerL7q+hoSEBNx444148cUXccUVV+D1118PGg4UFerz05fPSri/i9/mzZthsVhQWVmJ5ubmbkkukYyYCBEpaMKECdi4cSM0TQskSVu3bkVqaiqGDx/eLX7q1KnweDw4fvw4vvWtb4V8zjPPPBMffvghHnjggZCPZ2dno7KyMnDb4XCgtLS0xzZOmzYNGzZsQE5ODtLS0oRel38mmEhd0s6dO+H1evG73/0uUE/z5ptv9voz06ZNw4EDBzB27NiQj59xxhnwer3417/+hQsuuECofaecckqgdqmwsBCAL0HcsWOH0DpOP/rRjzBp0iQ8/fTTcLvduOKKK8L+TF9MmDChW/H0tm3bgm6H+7sAwMcff4xHHnkEf/rTn3DPPfdgxYoVePnllyPaVqLBwGJpIgUtW7YM5eXlWLlyJQ4dOoT33nsPa9aswerVq0MW2Z566qlYtGgRbrzxRrzzzjsoLS3F9u3b8dBDD+HPf/4zAOC+++7Djh07sGzZMuzduxeHDh1CcXExamtrAQDnn38+XnnlFXz00UfYt28fFi9e3K13qbNFixYhKysLP/zhD/HRRx+htLQU//znP7Fq1SocPXo05M8UFhbCZDLh/fffR01NTdAMsK7Gjh2L9vZ2PPXUUzh8+DBeeeWVQBF1T+655x58/PHHWLFiBXbv3o0vv/wS7733XqAoeNSoUVi8eDGWLFmCd999N9Bmf4IVqn3JyclYunQpfvrTn+Jvf/sbDhw4gFtvvRUtLS245ZZbem0P4EtUZs+ejXvuuQfXXntt2J65vrrjjjvw5Zdf4qc//Sk+//xzvP7663jppZf69HdpbGzEDTfcgFWrVuHiiy/Ga6+9hg0bNuDtt9+OaFuJBoWxJUpEFE7noma/UIXJ6FSIrGma9s9//lObOXOmlpCQoOXl5Wn33HOP1t7e3uPztrW1affff782atQoLT4+XsvPz9cuv/xybe/evUHPOXfuXM1qtWoZGRna/PnzAwW1drtdW7hwoZaWlqaNGDFCe+mll3otltY0X5H3jTfeqGVlZWlWq1UbM2aMduutt2p2u73Hv8d//dd/aXl5eZrJZNIWL17c499I0zTt0Ucf1fLz87XExERt/vz52h/+8IegIuBQxc3bt2/XLrzwQi0lJUVLTk7WzjzzzKDC39bWVu3uu+/W8vPztYSEBG3s2LHaCy+80Gv7WltbtZUrVwZe57x587Tt27cHfqanInC/559/XgMQ9DM9CVUs3flvrmmalp6err344ouB23/605+0sWPHalarVfvWt76lvfDCC336u9x8883aGWecESjq1jRN+93vfqdlZmZqR48eDdtmIiOZNK3LoD4RUYz4+9//josvvhhOp1NoAUaj/OpXv8Jbb72FvXv3Gt0UIuVwaIyIYlJ1dTXee+89jBs3TtokqKmpCfv378fatWuxcuVKo5tDpCQWSxNRTLrkkkvQ2NiIp59+2uim9GjFihVYv349LrvsMixZssTo5hApiUNjREREFLM4NEZEREQxi4kQERERxSwmQkRERBSzmAgRERFRzGIiRERERDGLiRARERHFLCZCREREFLOYCBEREVHM+v+vBLkW7Cbo4wAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "# select the molecule index\n",
    "start_id = 0\n",
    "\n",
    "mae_results = []\n",
    "x_axis = []\n",
    "ptable = {1: \"H\", 2: \"He\", 3: \"Li\", 4: \"Be\", 5: \"B\", 6: \"C\", 7: \"N\", 8: \"O\", 9: \"F\"}\n",
    "for molecule_idx in range(start_id, start_id + 10):\n",
    "    data_i = dataset[molecule_idx * 100]\n",
    "    H_i = build_final_matrix(\n",
    "        data_i, data_i.diagonal_hamiltonian, data_i.non_diagonal_hamiltonian)\n",
    "    hamiltonian_pyscf = matrix_transform(H_i.squeeze(), data_i.atoms.squeeze(), convention='back2pyscf')\n",
    "    for j in range(0, 100):\n",
    "        data_j = dataset[molecule_idx * 100 + j]\n",
    "        H_j = build_final_matrix(\n",
    "            data_j, data_j.diagonal_hamiltonian, data_j.non_diagonal_hamiltonian)\n",
    "        hamiltonian_pyscf = matrix_transform(H_j, data_j.atoms, convention='back2pyscf')\n",
    "        x_axis.append(int(molecule_idx))\n",
    "        mae_results.append(torch.mean((H_i - H_j).abs()))\n",
    "plt.yscale('log')\n",
    "plt.scatter(x=x_axis, y=mae_results, marker='x')\n",
    "plt.xlabel('molecule trajectory index')\n",
    "plt.ylabel('MAE (Hatree)')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Check the MD Simluations\n",
    "\n",
    "We can find that the geometric stuctures changes with the MD simulation steps."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import MDAnalysis as mda\n",
    "import MDAnalysis.analysis.msd as msd\n",
    "\n",
    "# select the molecule index\n",
    "molecule_idx = 0\n",
    "coord_list = []\n",
    "for i in range(molecule_idx * 100, (molecule_idx + 1)* 100):\n",
    "    coord_list.append(dataset[i].pos.numpy())\n",
    "molecule = dataset[molecule_idx * 100].atoms.squeeze().numpy()\n",
    "\n",
    "\n",
    "sol = mda.Universe.empty(molecule.shape[0], n_residues=1,trajectory=True)\n",
    "sol.add_TopologyAttr('type', molecule)\n",
    "\n",
    "sol.load_new(np.stack(coord_list))\n",
    "MSD = msd.EinsteinMSD(sol, select='all', msd_type='xyz', fft=True)\n",
    "MSD.run()\n",
    "msd = MSD.results.timeseries\n",
    "nframes = MSD.n_frames\n",
    "fig = plt.figure()\n",
    "ax = plt.axes()\n",
    "lagtimes = np.arange(nframes)\n",
    "ax.plot(lagtimes, msd,  ls=\"-\", label=r'MSD')\n",
    "plt.xlabel('time step')\n",
    "plt.ylabel('MSD (Angstrom)')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "QHBench",
   "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.18"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
