{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "ddced768",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import numpy as np\n",
    "import imageio"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "12a8d92c",
   "metadata": {},
   "outputs": [],
   "source": [
    "raw_path = '../md17'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "ec182975",
   "metadata": {},
   "outputs": [],
   "source": [
    "molecule_files = dict(\n",
    "    Aspirin=\"aspirin_dft.npz\",\n",
    "    Benzene=\"benzene_dft.npz\",\n",
    "    Ethanol=\"ethanol_dft.npz\",\n",
    "    Malonaldehyde=\"malonaldehyde_dft.npz\",\n",
    "    Naphthalene=\"naphthalene_dft.npz\",\n",
    "    Salicylic=\"salicylic_dft.npz\",\n",
    "    Toluene=\"toluene_dft.npz\",\n",
    "    Uracil=\"uracil_dft.npz\",\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "bfa711dd",
   "metadata": {},
   "outputs": [],
   "source": [
    "def read_mol(mol_name):\n",
    "    npz_file = np.load(os.path.join(raw_path, molecule_files[mol_name]))\n",
    "    z = npz_file['z']\n",
    "    x_all = npz_file['R']\n",
    "    x = x_all[:, z > 1]\n",
    "    return z, x_all, x"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "0505f6ba",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[6 6 6 8 8 1 1 1 1]\n"
     ]
    }
   ],
   "source": [
    "tar_mol = 'Malonaldehyde'\n",
    "z, x_all, x = read_mol(tar_mol)\n",
    "print(z)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "cf2fc00d",
   "metadata": {},
   "outputs": [],
   "source": [
    "dic = {1:'H', 6: 'C', 8:'O', 7:'N'}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "67e13ba1",
   "metadata": {},
   "outputs": [],
   "source": [
    "from xyz2mol import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "f87b6ee0",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[127947,\n",
       " 127957,\n",
       " 127967,\n",
       " 127977,\n",
       " 127987,\n",
       " 127997,\n",
       " 128007,\n",
       " 128017,\n",
       " 128027,\n",
       " 128037]"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "now_index = 128047\n",
    "past_index = [now_index - i*10  for i in range(10, 0, -1)]\n",
    "past_index"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "888b9f69",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_mol(ind):\n",
    "    print(ind)\n",
    "    x_mol = x_all[ind]\n",
    "    mols = xyz2mol(z.tolist(), x_mol.tolist(),\n",
    "                charge=0,\n",
    "                use_graph=True,\n",
    "                allow_charged_fragments=True,\n",
    "                embed_chiral=True,\n",
    "                use_huckel=False)\n",
    "    return mols[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "d51c0f6f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "128047\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<rdkit.Chem.rdchem.Mol at 0x7f5856d14b70>"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "example_mol = get_mol(now_index)\n",
    "example_mol"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "8b99aaf4",
   "metadata": {},
   "outputs": [],
   "source": [
    "from rdkit.Chem import PyMol\n",
    "v = PyMol.MolViewer()\n",
    "from PIL import Image, ImageDraw, ImageFont\n",
    "\n",
    "def cuthead(img, size=10):\n",
    "    im = np.array(img)\n",
    "    cutspace = im[:size,:,:]\n",
    "    cvs = np.ones_like(cutspace) * 255\n",
    "    im[:size,:,:] = cvs   \n",
    "    img2 = Image.fromarray(im).convert('RGB')\n",
    "    return img2\n",
    "\n",
    "def add_caption(img, molecule, method, step, mae = None, fontsize=20):\n",
    "    ime = ImageDraw.Draw(img)\n",
    "    # ft = ImageFont.truetype(\"times.ttf\",size=fontsize)\n",
    "    ft = ImageFont.load_default()\n",
    "    ime.text((10,10),f\"{molecule}, {method}\",(0,0,0),font=ft)\n",
    "    if mae is not None:\n",
    "        ime.text((10,15+fontsize),f\"Step={step}, MAE={mae:.4f}\",(0,0,0),font=ft)\n",
    "    else:\n",
    "        ime.text((10,15+fontsize),f\"Step={step}\",(0,0,0),font=ft)\n",
    "\n",
    "\n",
    "def show(ind):\n",
    "    example_mol = get_mol(ind)\n",
    "    # Visualize the example\n",
    "    # v = PyMol.MolViewer()\n",
    "    v.ShowMol(example_mol)\n",
    "    v.server.do(\"color yellow, elem c\")\n",
    "    v.server.do(\"color orange, elem h\")\n",
    "    v.server.do(\"color blue, elem n\")\n",
    "    v.server.do(\"color red, elem o\")\n",
    "    img = v.GetPNG(h=300)\n",
    "    # You may adjust the view in PyMol for better visualization\n",
    "    img = cuthead(img)\n",
    "    # add_caption(img, tar_mol, 'Example', 0, mae = 0.0, fontsize = 15)\n",
    "    return img"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "b6168044",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "128047\n"
     ]
    }
   ],
   "source": [
    "img = show(past_index[10])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "id": "92db3760",
   "metadata": {},
   "outputs": [],
   "source": [
    "img.save(f'vis/{tar_mol}_gt.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 197,
   "id": "15a94b76",
   "metadata": {},
   "outputs": [],
   "source": [
    "def set_rdmol_positions(rdkit_mol, pos):\n",
    "    \"\"\"\n",
    "    Args:\n",
    "        rdkit_mol:  An `rdkit.Chem.rdchem.Mol` object.\n",
    "        pos: (N_atoms, 3)\n",
    "    \"\"\"\n",
    "    mol = copy.deepcopy(rdkit_mol)\n",
    "    set_rdmol_positions_(mol, pos)\n",
    "    return mol\n",
    "\n",
    "\n",
    "def set_rdmol_positions_(mol, pos):\n",
    "    \"\"\"\n",
    "    Args:\n",
    "        rdkit_mol:  An `rdkit.Chem.rdchem.Mol` object.\n",
    "        pos: (N_atoms, 3)\n",
    "    \"\"\"\n",
    "    for i in range(pos.shape[0]):\n",
    "        mol.GetConformer(0).SetAtomPosition(i, pos[i].tolist())\n",
    "    return mol"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "id": "74ff904f",
   "metadata": {},
   "outputs": [],
   "source": [
    "loc_pred = np.array([[-1.1885,  0.3116, -0.6747],\n",
    "        [-0.0237,  0.8144, -1.1451],        [ 1.2061,  0.4384, -0.5264],        [ 1.2043, -0.2609,  0.6985],        [-0.0281, -0.8106,  1.1351],\n",
    "        [-1.2149, -0.4542,  0.5240]])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "ad53b94e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(8, 3)\n"
     ]
    }
   ],
   "source": [
    "print(loc_pred.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "id": "2c6c42af",
   "metadata": {},
   "outputs": [],
   "source": [
    "# x = np.array(x_all[now_index])\n",
    "\n",
    "x = np.array([[-1.1841,  0.3039, -0.6663],        [-0.0100,  0.7965, -1.1339],        [ 1.2122,  0.4357, -0.5211],        [ 1.2202, -0.2841,  0.7040],        [-0.0149, -0.8246,  1.1363],        [-1.2044, -0.4706,  0.5270],        [-2.1085,  0.6681, -1.1761],        [ 0.0214,  1.3515, -2.0826],\n",
    "        [ 2.1358,  0.8502, -0.8732],        [ 2.1501, -0.5980,  1.1671],        [-0.0215, -1.5188,  1.9750],        [-2.1958, -0.7096,  0.9437]])\n",
    "x[np.array(z) > 1] = loc_pred"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "id": "9fe23a93",
   "metadata": {},
   "outputs": [],
   "source": [
    "try:\n",
    "    mols = xyz2mol(z, x,\n",
    "                    charge=0,\n",
    "                    use_graph=True,\n",
    "                    allow_charged_fragments=True,\n",
    "                    embed_chiral=True,\n",
    "                    use_huckel=False)\n",
    "except Exception as e:\n",
    "    print(e)\n",
    "\n",
    "# print(mols)\n",
    "mol = mols[0]\n",
    "v.ShowMol(mol)\n",
    "v.server.do(\"color yellow, elem c\")\n",
    "v.server.do(\"color orange, elem h\")\n",
    "v.server.do(\"color blue, elem n\")\n",
    "v.server.do(\"color red, elem o\")\n",
    "img = v.GetPNG(h=300)\n",
    "# You may adjust the view in PyMol for better visualization\n",
    "img = cuthead(img)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "id": "6526990e",
   "metadata": {},
   "outputs": [],
   "source": [
    "img.save(f'vis/{tar_mol}_egnn.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "a96d59a0",
   "metadata": {},
   "outputs": [],
   "source": [
    "from rdkit.Chem import PyMol"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9b7090f2",
   "metadata": {},
   "source": [
    "Run 'pymol -R' in Bash before the following block to start PyMol first. "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "0a5b50ea",
   "metadata": {},
   "outputs": [
    {
     "ename": "ConnectionRefusedError",
     "evalue": "[Errno 111] Connection refused",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mConnectionRefusedError\u001b[0m                    Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-33-2f70a9c7a100>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[0;32m----> 1\u001b[0;31m \u001b[0mv\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mPyMol\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mMolViewer\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m",
      "\u001b[0;32m~/anaconda3/envs/protein/lib/python3.6/site-packages/rdkit/Chem/PyMol.py\u001b[0m in \u001b[0;36m__init__\u001b[0;34m(self, host, port, force, **kwargs)\u001b[0m\n\u001b[1;32m     35\u001b[0m       \u001b[0m_server\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     36\u001b[0m       \u001b[0mserv\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mServer\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m'http://%s:%d'\u001b[0m \u001b[0;34m%\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0mhost\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mport\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 37\u001b[0;31m       \u001b[0mserv\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mping\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     38\u001b[0m       \u001b[0m_server\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mserv\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     39\u001b[0m       \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mserver\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mserv\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/envs/protein/lib/python3.6/xmlrpc/client.py\u001b[0m in \u001b[0;36m__call__\u001b[0;34m(self, *args)\u001b[0m\n\u001b[1;32m   1110\u001b[0m         \u001b[0;32mreturn\u001b[0m \u001b[0m_Method\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m__send\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m\"%s.%s\"\u001b[0m \u001b[0;34m%\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m__name\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mname\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1111\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m__call__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 1112\u001b[0;31m         \u001b[0;32mreturn\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m__send\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m__name\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0margs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   1113\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1114\u001b[0m \u001b[0;31m##\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/envs/protein/lib/python3.6/xmlrpc/client.py\u001b[0m in \u001b[0;36m__request\u001b[0;34m(self, methodname, params)\u001b[0m\n\u001b[1;32m   1450\u001b[0m             \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m__handler\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1451\u001b[0m             \u001b[0mrequest\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 1452\u001b[0;31m             \u001b[0mverbose\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m__verbose\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   1453\u001b[0m             )\n\u001b[1;32m   1454\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/envs/protein/lib/python3.6/xmlrpc/client.py\u001b[0m in \u001b[0;36mrequest\u001b[0;34m(self, host, handler, request_body, verbose)\u001b[0m\n\u001b[1;32m   1152\u001b[0m         \u001b[0;32mfor\u001b[0m \u001b[0mi\u001b[0m \u001b[0;32min\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1153\u001b[0m             \u001b[0;32mtry\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 1154\u001b[0;31m                 \u001b[0;32mreturn\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msingle_request\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mhost\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mhandler\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mrequest_body\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mverbose\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   1155\u001b[0m             \u001b[0;32mexcept\u001b[0m \u001b[0mhttp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mclient\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mRemoteDisconnected\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1156\u001b[0m                 \u001b[0;32mif\u001b[0m \u001b[0mi\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/envs/protein/lib/python3.6/xmlrpc/client.py\u001b[0m in \u001b[0;36msingle_request\u001b[0;34m(self, host, handler, request_body, verbose)\u001b[0m\n\u001b[1;32m   1164\u001b[0m         \u001b[0;31m# issue XML-RPC request\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1165\u001b[0m         \u001b[0;32mtry\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 1166\u001b[0;31m             \u001b[0mhttp_conn\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msend_request\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mhost\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mhandler\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mrequest_body\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mverbose\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   1167\u001b[0m             \u001b[0mresp\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mhttp_conn\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mgetresponse\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1168\u001b[0m             \u001b[0;32mif\u001b[0m \u001b[0mresp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mstatus\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0;36m200\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/envs/protein/lib/python3.6/xmlrpc/client.py\u001b[0m in \u001b[0;36msend_request\u001b[0;34m(self, host, handler, request_body, debug)\u001b[0m\n\u001b[1;32m   1277\u001b[0m         \u001b[0mheaders\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mappend\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m\"User-Agent\"\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0muser_agent\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1278\u001b[0m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msend_headers\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mconnection\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mheaders\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 1279\u001b[0;31m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msend_content\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mconnection\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mrequest_body\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   1280\u001b[0m         \u001b[0;32mreturn\u001b[0m \u001b[0mconnection\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1281\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/envs/protein/lib/python3.6/xmlrpc/client.py\u001b[0m in \u001b[0;36msend_content\u001b[0;34m(self, connection, request_body)\u001b[0m\n\u001b[1;32m   1307\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1308\u001b[0m         \u001b[0mconnection\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mputheader\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m\"Content-Length\"\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mstr\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mlen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mrequest_body\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 1309\u001b[0;31m         \u001b[0mconnection\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mendheaders\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mrequest_body\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   1310\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1311\u001b[0m     \u001b[0;31m##\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/envs/protein/lib/python3.6/http/client.py\u001b[0m in \u001b[0;36mendheaders\u001b[0;34m(self, message_body, encode_chunked)\u001b[0m\n\u001b[1;32m   1280\u001b[0m         \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1281\u001b[0m             \u001b[0;32mraise\u001b[0m \u001b[0mCannotSendHeader\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 1282\u001b[0;31m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_send_output\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mmessage_body\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mencode_chunked\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mencode_chunked\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   1283\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1284\u001b[0m     def request(self, method, url, body=None, headers={}, *,\n",
      "\u001b[0;32m~/anaconda3/envs/protein/lib/python3.6/http/client.py\u001b[0m in \u001b[0;36m_send_output\u001b[0;34m(self, message_body, encode_chunked)\u001b[0m\n\u001b[1;32m   1040\u001b[0m         \u001b[0mmsg\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34mb\"\\r\\n\"\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mjoin\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_buffer\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1041\u001b[0m         \u001b[0;32mdel\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_buffer\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 1042\u001b[0;31m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msend\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mmsg\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   1043\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1044\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mmessage_body\u001b[0m \u001b[0;32mis\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/envs/protein/lib/python3.6/http/client.py\u001b[0m in \u001b[0;36msend\u001b[0;34m(self, data)\u001b[0m\n\u001b[1;32m    978\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msock\u001b[0m \u001b[0;32mis\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    979\u001b[0m             \u001b[0;32mif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mauto_open\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 980\u001b[0;31m                 \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mconnect\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    981\u001b[0m             \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    982\u001b[0m                 \u001b[0;32mraise\u001b[0m \u001b[0mNotConnected\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/envs/protein/lib/python3.6/http/client.py\u001b[0m in \u001b[0;36mconnect\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    950\u001b[0m         \u001b[0;34m\"\"\"Connect to the host and port specified in __init__.\"\"\"\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    951\u001b[0m         self.sock = self._create_connection(\n\u001b[0;32m--> 952\u001b[0;31m             (self.host,self.port), self.timeout, self.source_address)\n\u001b[0m\u001b[1;32m    953\u001b[0m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msock\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msetsockopt\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0msocket\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mIPPROTO_TCP\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0msocket\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mTCP_NODELAY\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    954\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/envs/protein/lib/python3.6/socket.py\u001b[0m in \u001b[0;36mcreate_connection\u001b[0;34m(address, timeout, source_address)\u001b[0m\n\u001b[1;32m    722\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    723\u001b[0m     \u001b[0;32mif\u001b[0m \u001b[0merr\u001b[0m \u001b[0;32mis\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 724\u001b[0;31m         \u001b[0;32mraise\u001b[0m \u001b[0merr\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    725\u001b[0m     \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    726\u001b[0m         \u001b[0;32mraise\u001b[0m \u001b[0merror\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m\"getaddrinfo returns an empty list\"\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/envs/protein/lib/python3.6/socket.py\u001b[0m in \u001b[0;36mcreate_connection\u001b[0;34m(address, timeout, source_address)\u001b[0m\n\u001b[1;32m    711\u001b[0m             \u001b[0;32mif\u001b[0m \u001b[0msource_address\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    712\u001b[0m                 \u001b[0msock\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mbind\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0msource_address\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 713\u001b[0;31m             \u001b[0msock\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mconnect\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0msa\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    714\u001b[0m             \u001b[0;31m# Break explicitly a reference cycle\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    715\u001b[0m             \u001b[0merr\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mConnectionRefusedError\u001b[0m: [Errno 111] Connection refused"
     ]
    }
   ],
   "source": [
    "v = PyMol.MolViewer()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3135137d",
   "metadata": {},
   "source": [
    "## Settings in PyMol\n",
    "\n",
    "Display -> Background -> White\n",
    "\n",
    "Display -> Color Space -> CMYK\n",
    "\n",
    "Setting -> Lines & Sticks -> Ball and Stick\n",
    "\n",
    "Setting -> Lines & Sticks -> Ball and Stick Ratio -> 1.5\n",
    "\n",
    "(PyMol>) set stick_radius=0.15"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "2eb9d5ce",
   "metadata": {},
   "outputs": [],
   "source": [
    "from PIL import Image, ImageDraw, ImageFont"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "9ab2ecae",
   "metadata": {},
   "outputs": [],
   "source": [
    "def cuthead(img, size=10):\n",
    "    im = np.array(img)\n",
    "    cutspace = im[:size,:,:]\n",
    "    cvs = np.ones_like(cutspace) * 255\n",
    "    im[:size,:,:] = cvs   \n",
    "    img2 = Image.fromarray(im).convert('RGB')\n",
    "    return img2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "08b60583",
   "metadata": {},
   "outputs": [],
   "source": [
    "def add_caption(img, molecule, method, step, mae = None, fontsize=20):\n",
    "    ime = ImageDraw.Draw(img)\n",
    "    ft = ImageFont.truetype(\"times.ttf\",size=fontsize)\n",
    "    ime.text((10,10),f\"{molecule}, {method}\",(0,0,0),font=ft)\n",
    "    if mae is not None:\n",
    "        ime.text((10,15+fontsize),f\"Step={step}, MAE={mae:.4f}\",(0,0,0),font=ft)\n",
    "    else:\n",
    "        ime.text((10,15+fontsize),f\"Step={step}\",(0,0,0),font=ft)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "2ab0f23b",
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'v' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-18-2f203c43e52c>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[0;31m# Visualize the example\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 2\u001b[0;31m \u001b[0mv\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mShowMol\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mexample_mol\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m      3\u001b[0m \u001b[0mv\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mserver\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdo\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m\"color yellow, elem c\"\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      4\u001b[0m \u001b[0mv\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mserver\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdo\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m\"color orange, elem h\"\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      5\u001b[0m \u001b[0mv\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mserver\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdo\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m\"color blue, elem n\"\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mNameError\u001b[0m: name 'v' is not defined"
     ]
    }
   ],
   "source": [
    "# Visualize the example\n",
    "v.ShowMol(example_mol)\n",
    "v.server.do(\"color yellow, elem c\")\n",
    "v.server.do(\"color orange, elem h\")\n",
    "v.server.do(\"color blue, elem n\")\n",
    "v.server.do(\"color red, elem o\")\n",
    "img = v.GetPNG(h=300)\n",
    "# You may adjust the view in PyMol for better visualization\n",
    "img = cuthead(img)\n",
    "add_caption(img, tar_mol, 'Example', 0, mae = 0.0, fontsize = 15)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "1036ff76",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAWYAAAEsCAIAAAB/h45LAABvB0lEQVR4nO2deZhcRbnw36o6W+89PfuWTNbJNtlDQiBAYgj7LosiiwrCVRQRFK/eT/0+rwqowNULKojKIqDsIexECBAgkJUsk2Qms+/TM9PTe59zqt7vjzPTGQKEjCSZSajf00+eTveZ7url/PqtqrfeIogIEolEcmDQkW6ARCI5kpDKkEgkw0AqQyKRDAOpDIlEMgykMiQSyTCQypBIJMNAKkMikQwDqQyJRDIMpDIkEskwkMqQSCTDQCpDIpEMA6kMiUQyDA6rMh588MFzzjlnuHeNfnp7e3/84x+vWLFipBsikRx68IBJJBKXXnrpgR9/ePhY0VBKhRCHrQ233HKLpmkLFy48bM8okYwUw4gy/va3vz388MM1NTUHz1cHgaeeeupPf/oTANTU1DgvKZ1O33TTTYlE4rC14eabb/7pT3962J5OIhlBDlQZiLh58+YZM2bcddddh7RBw4UQMn78+KG36Lp+6623er3ew9kMt9t9OJ9OIhkpDlQZq1atOvXUU7/1rW/99a9/jcfjQ+/63ve+FwwGr7vuugceeAAA1qxZs3z58j//+c9nnnmm1+s9//zzo9EoAPT09PzoRz9yOvwbNmw455xzvvnNb86ZM6eysnLoXevXrz/77LN///vf//CHP/T5fMuWLUun0wf+ejjnDzzwwM6dOwFg/vz5hBBCyEMPPXTJJZcQQq666ioAQMSbb765sLDQMIylS5f29PQAwObNmy+44ILbbrvtN7/5TV5e3sKFC3t7e//7v/87GAxWVVU1Nzfv56Xtw549e0455RS/3z9v3ryNGzceeOMlkiOAA+zAXHnllbZtJxKJYDB41113ZW/ftGnTCSec0N3dXV1dfc011yBiKBQCgCuvvLKtrW3Dhg2hUOiGG25AxJ///OfZDn9VVRUAnHPOOel0ep+75syZAwCnnHLK+vXrGxsbvV7v448/vv+2vfLKK/u8qOrqakQMh8MXXXRRMBiMx+N/+MMffvKTnyQSCURsaWnJy8traGioqanx+/133nknIh577LEAcN5557333nstLS3l5eXnnXfeG2+8EQ6Hp0+f/l//9V/7eWmIeMcddzjtz2QyZ5555s6dO/v7+7/5zW+OHz/esqwDfJMlktHPASlj8+bNt956q3P9hhtumDp1avauhoaGwsLChx56KJPJOLdwzkOh0GOPPeb89yc/+cm4ceOc67/4xS+yY4SzZs264447so8z9K6qqqrf//73zvXZs2f/8Y9/3H/zHGU4Yxm2bd93332OMhDRNM3ly5efdNJJv/rVrz72b5csWfLf//3fzvUFCxZkDzv33HN/+MMfOtcvu+yya6+9dv8vLauMF1988WP9JZEcHRxQx+T222+/+eabnSD/jjvuqK6ufvXVV527xo4du3LlykceeWTMmDH3338/AFBKXS5X9m+nTJnS19fnXB/a4TcMY+hTDL1r6HXGGA6nOilj7Gtf+9qUKVOc/6qq+pvf/Obdd9+NRCJDDzNN84EHHli+fPnbb7+dffxPel5KqXN9Py8tS2Nj40UXXTT0Lc42RiI5Cvh0ZXR0dHR1dWVPAMuy5s6d+/vf/z57wDHHHLNq1aqXX375+uuv37p1q3Mj59y50traevjPGUT83//9XwDo7u6+/fbbN27c+Je//OWhhx5y7m1ra5s1a9aOHTt+/etfn3DCCcN98P2/tJKSkrVr12bHXzZu3OiMg0gkRwefooyenp4rr7zyP/7jP7K3KIpy7bXXrlq16v7777cs66233vrlL3/Z0tLi9XpdLpdpms5hDz/8cG9v744dO373u9/ddNNNAICIjY2N3d3dqVQqkUiEw+HseTX0rlQq1dnZ2dLSgoipVCocDjc1Ne0n0BBC7N69GwDC4bBzSyQS+c53vuNyuZqbmy+66KJf/vKXU6dOveWWW6666qqnn35aCPHMM88kEonvfve7LpcrHA5Ho9EXX3wxnU5nn9eyrI6OjtbWVs55Op1ub29vbW3d/0trbm7u7u5OJpPLli1jjF122WXNzc0tLS1PPfVUeXn5v/fZSCSjkf33W8aOHesc9tprrzm3vPbaa9m/veCCC958882XX3557ty5ubm5v/jFL5xjSktLv/vd7xYVFZWXl2cHLH796187fzVv3rzp06cDQElJyfe+97197po3b55z/cc//nFpaalz/Y477ujt7R07duwVV1yxTws/KWe0ubn5xBNPdP4WESsrK53bn3rqqbq6usrKyoKCgjvvvPP666+fNm1aS0vLcccd5xxw4403Zq9fccUVZ5xxhnP961//+ie9tGzMNWHCBETctm3b8ccf7/P5Tj311Pb29gPpH0okRwoED8E+JmVlZXfeeecXv/jFg/7IV1999b333nvQH/bAOXQvTSI5IlAO+iP29vbG43EnwieEHKyHjcViK1eu/OY3v3mwHvDf4BC9NInkCOIgRxnxeNzn8znXf/WrX/3whz88iA8+shzFL00iOXAOScdEIpEcrch6GRKJZBhIZUgkkmEglSGRSIaBVIZEIhkGUhkSiWQYSGVIJJJh8OnKqKurO/PMMwOBwNSpUx977LF77rnnEDVFCPHDH/4wEAhMmTLlzTff3P/BJ510krOy9qWXXtrnrv7+fp/P59xr23b29mQy+ZWvfGWfg88991zyET51+eyBNPWTjjlYt0skI8OnppTPmDHjm9/8ZiQSqa+vv+OOOyZPnuzc3t7eft999x3E3PWf/OQn8+bN6+joeOaZZ/x+f2Nj434ONk3zBz/4gdvtPuWUU/a56/bbb3e73cuXL3fq92S56667CCG7d+8eeqMQ4qOlQ3/wgx/EYrHP2NRPOuZg3S6RjAifogzTNCmlmzZtyt7i1LCybXvFihXZQjifnXg87nK5nnzySee/J5xwwvXXX7//P3nkkUe+9a1vEUJ27NiRvZFz/uUvf3nevHnOKrIsQoirr766qqrqow87tELPwWrqJx1zsG6XSEaKT+mYqKp64403fvnLX167dq1zy/XXXw8AX/nKV15++eVvf/vbiqLAx1W7/KQymcuXL/9oR4AQsmbNmlQqNXv2bOdZ5s+fn63isx9OPfXU6dOn33nnndlbnnvuufPOO++jR+6ndulQhpYO/SxN/aRjDtbtEslI8eljGbfddtsPfvCDiy+++JRTTnn77bedGx955JF58+b9/ve/t23bNM3vfve7v/vd71paWhYtWnThhRfatn3++eevXr167dq199577xtvvLFmzZqf/exnAPDqq69+rLqampoAoKCgwHn8nJyclpaWA3kBN91004MPPuiU/AWA559//vzzz//oYU8++eQ555xz2WWXUUqdssb7MGnSJEKIoihXXHGFc8tnaeonHXOwbpdIRooDmjG58sora2trV6xYccYZZ9xwww373Pvaa6+tWrVqypQpgUDg7rvvrqurq62t7e7uDoVCZ5xxRnFx8dy5c6+77rqnn356P0/hLAzNVvfLZDKqqh5I27785S+HQiFnPKK6urqqqorSfV/Uli1bpk6dyhhzu91f/epXnYJd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",
      "text/plain": [
       "<PIL.Image.Image image mode=RGB size=358x300 at 0x7FF0A823BE10>"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "img"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "f8dc1c1f",
   "metadata": {},
   "outputs": [],
   "source": [
    "os.makedirs('vis',exist_ok=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "6bd75b16",
   "metadata": {},
   "outputs": [],
   "source": [
    "from tqdm import tqdm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ff79464f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "a7b78be2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(133770, 8, 3)"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tar_mol = 'Uracil'\n",
    "z, x_all, x = read_mol(tar_mol)\n",
    "x.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "972cf2e8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(5823, 8, 3)"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "temp_x = x[127947:max(327947, len(x))]\n",
    "temp_x.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "8537f82c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 1500x600 with 0 Axes>"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 1500x600 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import matplotlib\n",
    "matplotlib.rcParams.update({'font.size': 15})\n",
    "plt.figure(figsize=(15, 6))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "c6206201",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "data = temp_x[:, 0, 2]\n",
    "data = data / np.max(np.abs(data))\n",
    "plt.xlabel('t')\n",
    "plt.ylabel('coordinates')\n",
    "plt.title(tar_mol.upper())\n",
    "plt.plot(data)\n",
    "plt.savefig(f'vis/{tar_mol}_T.pdf')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "01716693",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4ebab384",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3.6.13 ('protein')",
   "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.6.13"
  },
  "vscode": {
   "interpreter": {
    "hash": "0efb669c6e3cfb88bb9dab8f7ee3cbda7c9159c050b184dbe0517885df69196f"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
