{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.append(\"../..\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "from train import Config, LitQuetzal\n",
    "import py3Dmol\n",
    "from draw import make_html\n",
    "\n",
    "ckpt = '../../checkpoints/geom.ckpt'\n",
    "DEVICE = \"cuda\" if torch.cuda.is_available() else \"cpu\"\n",
    "DIFF_STEPS = 120\n",
    "\n",
    "lit = LitQuetzal.load_from_checkpoint(ckpt, map_location=DEVICE)\n",
    "model = lit.ema.module\n",
    "model.eval();\n",
    "\n",
    "from chem import parse_xyz, Molecule\n",
    "import torch\n",
    "\n",
    "kwargs = {\n",
    "    \"device\": DEVICE,\n",
    "    \"num_steps\": DIFF_STEPS,\n",
    "    \"pbar\": True,\n",
    "    \"max_len\": 184,\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 34%|███▍      | 61/177 [00:25<00:48,  2.37it/s]\n"
     ]
    }
   ],
   "source": [
    "a,x = parse_xyz(\"benzene.xyz\")\n",
    "\n",
    "out = model.generate(6, prefix=(a, x), **kwargs)\n",
    "torch.save(out, \"benzene.pt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/3dmoljs_load.v0": "<div id=\"3dmolviewer_17465448883622317\"  style=\"position: relative; width: 4200px; height: 700px;\">\n        <p id=\"3dmolwarning_17465448883622317\" style=\"background-color:#ffcccc;color:black\">3Dmol.js failed to load for some reason.  Please check your browser console for error messages.<br></p>\n        </div>\n<script>\n\nvar loadScriptAsync = function(uri){\n  return new Promise((resolve, reject) => {\n    //this is to ignore the existence of requirejs amd\n    var savedexports, savedmodule;\n    if (typeof exports !== 'undefined') savedexports = exports;\n    else exports = {}\n    if (typeof module !== 'undefined') savedmodule = module;\n    else module = {}\n\n    var tag = document.createElement('script');\n    tag.src = uri;\n    tag.async = true;\n    tag.onload = () => {\n        exports = savedexports;\n        module = savedmodule;\n        resolve();\n    };\n  var firstScriptTag = document.getElementsByTagName('script')[0];\n  firstScriptTag.parentNode.insertBefore(tag, firstScriptTag);\n});\n};\n\nif(typeof $3Dmolpromise === 'undefined') {\n$3Dmolpromise = null;\n  $3Dmolpromise = loadScriptAsync('XXXX');\n}\n\nvar viewer_17465448883622317 = null;\nvar warn = document.getElementById(\"3dmolwarning_17465448883622317\");\nif(warn) {\n    warn.parentNode.removeChild(warn);\n}\n$3Dmolpromise.then(function() {\nvar viewergrid_17465448883622317 = null;\nviewergrid_17465448883622317 = $3Dmol.createViewerGrid(document.getElementById(\"3dmolviewer_17465448883622317\"),{rows: 1, cols: 6, control_all: true},{backgroundColor:\"white\"});\nviewer_17465448883622317 = viewergrid_17465448883622317[0][0];\nviewergrid_17465448883622317[0][0].zoomTo();viewergrid_17465448883622317[0][1].zoomTo();viewergrid_17465448883622317[0][2].zoomTo();viewergrid_17465448883622317[0][3].zoomTo();viewergrid_17465448883622317[0][4].zoomTo();viewergrid_17465448883622317[0][5].zoomTo();\tviewergrid_17465448883622317[0][0].rotate(180,{\"x\": 0, \"y\": 1});\n\tviewergrid_17465448883622317[0][1].rotate(180,{\"x\": 0, \"y\": 1});\n\tviewergrid_17465448883622317[0][2].rotate(180,{\"x\": 0, \"y\": 1});\n\tviewergrid_17465448883622317[0][3].rotate(180,{\"x\": 0, \"y\": 1});\n\tviewergrid_17465448883622317[0][4].rotate(180,{\"x\": 0, \"y\": 1});\n\tviewergrid_17465448883622317[0][5].rotate(180,{\"x\": 0, \"y\": 1});\n\tviewergrid_17465448883622317[0][0].translate(50,0);\n\tviewergrid_17465448883622317[0][1].translate(50,0);\n\tviewergrid_17465448883622317[0][2].translate(50,0);\n\tviewergrid_17465448883622317[0][3].translate(50,0);\n\tviewergrid_17465448883622317[0][4].translate(50,0);\n\tviewergrid_17465448883622317[0][5].translate(50,0);\n\tviewergrid_17465448883622317[0][0].addModel(\"6\\n\\nC -1.213100 -0.688400 0.000000\\nC -1.202800 0.706400 0.000100\\nC 0.010400 1.394800 -0.000100\\nC 1.213100 0.688400 0.000000\\nC 1.202800 -0.706300 0.000000\\nC -0.010300 -1.394800 0.000000\\n\",\"xyz\");\n\tviewergrid_17465448883622317[0][0].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}, \"sphere\": {\"scale\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}});\n\tviewergrid_17465448883622317[0][0].zoomTo();\n\tviewergrid_17465448883622317[0][1].zoomTo();\n\tviewergrid_17465448883622317[0][2].zoomTo();\n\tviewergrid_17465448883622317[0][3].zoomTo();\n\tviewergrid_17465448883622317[0][4].zoomTo();\n\tviewergrid_17465448883622317[0][5].zoomTo();\n\tviewergrid_17465448883622317[0][0].addModel(\"30\\n\\nC -1.213100 -0.688400 0.000000\\nC -1.202800 0.706400 0.000100\\nC 0.010400 1.394800 -0.000100\\nC 1.213100 0.688400 0.000000\\nC 1.202800 -0.706300 0.000000\\nC -0.010300 -1.394800 0.000000\\nH -0.018030 -2.474138 0.004776\\nH 2.135739 -1.244931 0.004688\\nC 2.539399 1.421936 0.025036\\nC 2.982591 1.474046 1.430418\\nN 3.921240 0.758457 2.006648\\nN 3.900221 1.042952 3.317332\\nC 2.944724 1.909171 3.492186\\nC 2.513160 2.500145 4.734679\\nC 3.177326 2.188171 5.904263\\nC 2.747908 2.747484 7.085057\\nC 1.665588 3.603690 7.115953\\nC 0.989325 3.916589 5.927606\\nC 1.426118 3.366275 4.747217\\nH 0.926509 3.611831 3.813351\\nH 0.144391 4.592347 5.923111\\nH 1.335539 4.045459 8.036715\\nH 3.264376 2.524146 8.013174\\nH 4.033709 1.506919 5.880424\\nO 2.339615 2.210736 2.304955\\nH 2.410699 2.436678 -0.359896\\nH 3.273877 0.882054 -0.576789\\nH 0.017550 2.471321 0.003425\\nH -2.125790 1.258959 0.005219\\nH -2.148932 -1.223776 0.010567\\n\",\"xyz\");\n\tviewergrid_17465448883622317[0][0].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2}, \"sphere\": {\"scale\": 0.2}});\n\tviewergrid_17465448883622317[0][0].zoomTo();\n\tviewergrid_17465448883622317[0][1].zoomTo();\n\tviewergrid_17465448883622317[0][2].zoomTo();\n\tviewergrid_17465448883622317[0][3].zoomTo();\n\tviewergrid_17465448883622317[0][4].zoomTo();\n\tviewergrid_17465448883622317[0][5].zoomTo();\n\tviewergrid_17465448883622317[0][1].addModel(\"6\\n\\nC -1.213100 -0.688400 0.000000\\nC -1.202800 0.706400 0.000100\\nC 0.010400 1.394800 -0.000100\\nC 1.213100 0.688400 0.000000\\nC 1.202800 -0.706300 0.000000\\nC -0.010300 -1.394800 0.000000\\n\",\"xyz\");\n\tviewergrid_17465448883622317[0][1].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}, \"sphere\": {\"scale\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}});\n\tviewergrid_17465448883622317[0][0].zoomTo();\n\tviewergrid_17465448883622317[0][1].zoomTo();\n\tviewergrid_17465448883622317[0][2].zoomTo();\n\tviewergrid_17465448883622317[0][3].zoomTo();\n\tviewergrid_17465448883622317[0][4].zoomTo();\n\tviewergrid_17465448883622317[0][5].zoomTo();\n\tviewergrid_17465448883622317[0][1].addModel(\"36\\n\\nC -1.213100 -0.688400 0.000000\\nC -1.202800 0.706400 0.000100\\nC 0.010400 1.394800 -0.000100\\nC 1.213100 0.688400 0.000000\\nC 1.202800 -0.706300 0.000000\\nC -0.010300 -1.394800 0.000000\\nH -0.004432 -2.478876 0.010198\\nH 2.128450 -1.264063 0.008679\\nC 2.524207 1.443601 -0.027344\\nC 2.652565 2.381227 1.122849\\nN 1.958300 3.427370 1.396010\\nC 2.499694 3.902492 2.540891\\nN 3.501983 3.200059 2.982308\\nO 3.612514 2.190018 2.051783\\nC 2.000316 5.148344 3.194951\\nC 2.342710 5.158673 4.689536\\nC 1.159495 4.752924 5.531057\\nC 0.336425 3.686753 4.823693\\nC -0.311663 4.269026 3.565942\\nC 0.504828 5.395116 2.958313\\nH 0.278725 5.496944 1.899887\\nH 0.266782 6.351463 3.437191\\nH -0.431351 3.469709 2.834886\\nH -1.311631 4.651303 3.798563\\nH -0.425992 3.298613 5.488540\\nH 0.998585 2.844114 4.588436\\nH 1.548324 4.361475 6.488829\\nH 0.554441 5.617014 5.754616\\nH 3.183387 4.461619 4.854927\\nH 2.677376 6.167922 4.998089\\nH 2.516006 5.976359 2.700038\\nH 3.363754 0.752754 -0.005100\\nH 2.572966 2.032949 -0.952056\\nH 0.014265 2.470416 -0.008448\\nH -2.134101 1.262881 0.003624\\nH -2.147239 -1.216597 0.009210\\n\",\"xyz\");\n\tviewergrid_17465448883622317[0][1].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2}, \"sphere\": {\"scale\": 0.2}});\n\tviewergrid_17465448883622317[0][0].zoomTo();\n\tviewergrid_17465448883622317[0][1].zoomTo();\n\tviewergrid_17465448883622317[0][2].zoomTo();\n\tviewergrid_17465448883622317[0][3].zoomTo();\n\tviewergrid_17465448883622317[0][4].zoomTo();\n\tviewergrid_17465448883622317[0][5].zoomTo();\n\tviewergrid_17465448883622317[0][2].addModel(\"6\\n\\nC -1.213100 -0.688400 0.000000\\nC -1.202800 0.706400 0.000100\\nC 0.010400 1.394800 -0.000100\\nC 1.213100 0.688400 0.000000\\nC 1.202800 -0.706300 0.000000\\nC -0.010300 -1.394800 0.000000\\n\",\"xyz\");\n\tviewergrid_17465448883622317[0][2].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}, \"sphere\": {\"scale\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}});\n\tviewergrid_17465448883622317[0][0].zoomTo();\n\tviewergrid_17465448883622317[0][1].zoomTo();\n\tviewergrid_17465448883622317[0][2].zoomTo();\n\tviewergrid_17465448883622317[0][3].zoomTo();\n\tviewergrid_17465448883622317[0][4].zoomTo();\n\tviewergrid_17465448883622317[0][5].zoomTo();\n\tviewergrid_17465448883622317[0][2].addModel(\"41\\n\\nC -1.213100 -0.688400 0.000000\\nC -1.202800 0.706400 0.000100\\nC 0.010400 1.394800 -0.000100\\nC 1.213100 0.688400 0.000000\\nC 1.202800 -0.706300 0.000000\\nC -0.010300 -1.394800 0.000000\\nH -0.002209 -2.467011 -0.000866\\nH 2.129423 -1.238221 -0.016465\\nC 2.525495 1.435942 -0.036208\\nH 2.404378 2.439462 0.339938\\nH 2.922409 1.466878 -1.053498\\nS 3.852471 0.632562 0.943249\\nC 3.422229 1.139699 2.619128\\nC 2.889325 0.057973 3.527455\\nC 1.555884 -0.597148 3.110142\\nC 0.431508 0.343283 3.193823\\nN -0.436905 1.084121 3.304483\\nC 1.279855 -1.798709 3.984837\\nN 1.338488 -2.983134 3.461296\\nC 1.112037 -4.063070 4.226259\\nC 1.164831 -5.345672 3.642859\\nC 0.939642 -6.465506 4.424317\\nC 0.621551 -6.345369 5.772864\\nC 0.567314 -5.120112 6.364498\\nC 0.799135 -3.946705 5.609543\\nC 0.750651 -2.647716 6.163056\\nC 0.983341 -1.582166 5.353107\\nH 0.940459 -0.548325 5.721911\\nH 0.528158 -2.510288 7.209302\\nH 0.348045 -5.046422 7.417346\\nH 0.465641 -7.242256 6.329447\\nH 0.966264 -7.425663 3.951787\\nH 1.373779 -5.398890 2.590406\\nH 1.623735 -0.914649 2.055014\\nH 3.605971 -0.763221 3.618250\\nH 2.775626 0.491409 4.513928\\nH 4.359272 1.510460 3.031120\\nH 2.705852 1.966765 2.542784\\nH 0.019642 2.475830 -0.002567\\nH -2.139742 1.248878 0.019417\\nH -2.150690 -1.230321 0.005752\\n\",\"xyz\");\n\tviewergrid_17465448883622317[0][2].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2}, \"sphere\": {\"scale\": 0.2}});\n\tviewergrid_17465448883622317[0][0].zoomTo();\n\tviewergrid_17465448883622317[0][1].zoomTo();\n\tviewergrid_17465448883622317[0][2].zoomTo();\n\tviewergrid_17465448883622317[0][3].zoomTo();\n\tviewergrid_17465448883622317[0][4].zoomTo();\n\tviewergrid_17465448883622317[0][5].zoomTo();\n\tviewergrid_17465448883622317[0][3].addModel(\"6\\n\\nC -1.213100 -0.688400 0.000000\\nC -1.202800 0.706400 0.000100\\nC 0.010400 1.394800 -0.000100\\nC 1.213100 0.688400 0.000000\\nC 1.202800 -0.706300 0.000000\\nC -0.010300 -1.394800 0.000000\\n\",\"xyz\");\n\tviewergrid_17465448883622317[0][3].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}, \"sphere\": {\"scale\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}});\n\tviewergrid_17465448883622317[0][0].zoomTo();\n\tviewergrid_17465448883622317[0][1].zoomTo();\n\tviewergrid_17465448883622317[0][2].zoomTo();\n\tviewergrid_17465448883622317[0][3].zoomTo();\n\tviewergrid_17465448883622317[0][4].zoomTo();\n\tviewergrid_17465448883622317[0][5].zoomTo();\n\tviewergrid_17465448883622317[0][3].addModel(\"33\\n\\nC -1.213100 -0.688400 0.000000\\nC -1.202800 0.706400 0.000100\\nC 0.010400 1.394800 -0.000100\\nC 1.213100 0.688400 0.000000\\nC 1.202800 -0.706300 0.000000\\nC -0.010300 -1.394800 0.000000\\nH -0.020136 -2.469465 0.006182\\nH 2.141659 -1.239948 -0.001089\\nC 2.525527 1.431479 -0.010126\\nN 3.464923 0.784829 0.889917\\nC 3.189960 0.798428 2.237596\\nN 2.108095 1.309025 2.653073\\nC 1.687161 1.185786 4.020471\\nC 1.438091 -0.274989 4.434271\\nC 2.722459 -1.033167 4.782829\\nC 3.659682 -1.241346 3.598991\\nH 3.130458 -1.747115 2.793043\\nC 4.270917 0.060010 3.094207\\nH 5.158171 -0.138792 2.505382\\nH 4.543060 0.683460 3.945659\\nH 4.471629 -1.917307 3.909241\\nH 2.437603 -2.003519 5.181113\\nH 3.255847 -0.489712 5.567626\\nH 0.919072 -0.792544 3.641392\\nH 0.788466 -0.280447 5.321832\\nH 0.745746 1.720924 4.093947\\nH 2.421556 1.648989 4.709040\\nH 4.423568 0.789190 0.623981\\nH 2.964961 1.412726 -1.008852\\nH 2.343503 2.472413 0.303002\\nH 0.020634 2.468597 0.013091\\nH -2.133054 1.251712 0.005452\\nH -2.149838 -1.219854 -0.002360\\n\",\"xyz\");\n\tviewergrid_17465448883622317[0][3].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2}, \"sphere\": {\"scale\": 0.2}});\n\tviewergrid_17465448883622317[0][0].zoomTo();\n\tviewergrid_17465448883622317[0][1].zoomTo();\n\tviewergrid_17465448883622317[0][2].zoomTo();\n\tviewergrid_17465448883622317[0][3].zoomTo();\n\tviewergrid_17465448883622317[0][4].zoomTo();\n\tviewergrid_17465448883622317[0][5].zoomTo();\n\tviewergrid_17465448883622317[0][4].addModel(\"6\\n\\nC -1.213100 -0.688400 0.000000\\nC -1.202800 0.706400 0.000100\\nC 0.010400 1.394800 -0.000100\\nC 1.213100 0.688400 0.000000\\nC 1.202800 -0.706300 0.000000\\nC -0.010300 -1.394800 0.000000\\n\",\"xyz\");\n\tviewergrid_17465448883622317[0][4].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}, \"sphere\": {\"scale\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}});\n\tviewergrid_17465448883622317[0][0].zoomTo();\n\tviewergrid_17465448883622317[0][1].zoomTo();\n\tviewergrid_17465448883622317[0][2].zoomTo();\n\tviewergrid_17465448883622317[0][3].zoomTo();\n\tviewergrid_17465448883622317[0][4].zoomTo();\n\tviewergrid_17465448883622317[0][5].zoomTo();\n\tviewergrid_17465448883622317[0][4].addModel(\"24\\n\\nC -1.213100 -0.688400 0.000000\\nC -1.202800 0.706400 0.000100\\nC 0.010400 1.394800 -0.000100\\nC 1.213100 0.688400 0.000000\\nC 1.202800 -0.706300 0.000000\\nC -0.010300 -1.394800 0.000000\\nH -0.006029 -2.475557 0.007452\\nH 2.143007 -1.236458 0.001897\\nO 2.413582 1.361001 0.033327\\nC 2.862876 1.865870 -1.229546\\nC 1.863181 2.750107 -1.883521\\nN 1.121395 2.445928 -2.910869\\nC 0.334191 3.531970 -3.070861\\nN 0.562489 4.470629 -2.204864\\nN 1.542811 3.972167 -1.437933\\nH 1.888711 4.496434 -0.637295\\nN -0.560955 3.648972 -4.092463\\nH -1.278650 4.350892 -3.968868\\nH -0.863323 2.763223 -4.496794\\nH 3.086230 1.034333 -1.921013\\nH 3.807772 2.413815 -1.016483\\nH 0.015809 2.477149 0.012909\\nH -2.126117 1.273269 -0.012349\\nH -2.148573 -1.217052 -0.000857\\n\",\"xyz\");\n\tviewergrid_17465448883622317[0][4].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2}, \"sphere\": {\"scale\": 0.2}});\n\tviewergrid_17465448883622317[0][0].zoomTo();\n\tviewergrid_17465448883622317[0][1].zoomTo();\n\tviewergrid_17465448883622317[0][2].zoomTo();\n\tviewergrid_17465448883622317[0][3].zoomTo();\n\tviewergrid_17465448883622317[0][4].zoomTo();\n\tviewergrid_17465448883622317[0][5].zoomTo();\n\tviewergrid_17465448883622317[0][5].addModel(\"6\\n\\nC -1.213100 -0.688400 0.000000\\nC -1.202800 0.706400 0.000100\\nC 0.010400 1.394800 -0.000100\\nC 1.213100 0.688400 0.000000\\nC 1.202800 -0.706300 0.000000\\nC -0.010300 -1.394800 0.000000\\n\",\"xyz\");\n\tviewergrid_17465448883622317[0][5].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}, \"sphere\": {\"scale\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}});\n\tviewergrid_17465448883622317[0][0].zoomTo();\n\tviewergrid_17465448883622317[0][1].zoomTo();\n\tviewergrid_17465448883622317[0][2].zoomTo();\n\tviewergrid_17465448883622317[0][3].zoomTo();\n\tviewergrid_17465448883622317[0][4].zoomTo();\n\tviewergrid_17465448883622317[0][5].zoomTo();\n\tviewergrid_17465448883622317[0][5].addModel(\"67\\n\\nC -1.213100 -0.688400 0.000000\\nC -1.202800 0.706400 0.000100\\nC 0.010400 1.394800 -0.000100\\nC 1.213100 0.688400 0.000000\\nC 1.202800 -0.706300 0.000000\\nC -0.010300 -1.394800 0.000000\\nH -0.006453 -2.470997 0.003944\\nH 2.127469 -1.240785 0.013119\\nC 2.546854 1.399566 0.045150\\nC 3.031306 1.130175 1.433987\\nN 4.015076 0.318734 1.748731\\nN 4.046648 0.245220 3.067031\\nN 3.145060 0.947771 3.599599\\nN 2.455612 1.546585 2.601681\\nC 1.355788 2.434855 2.838260\\nC 0.070767 1.706601 3.135583\\nC -1.172791 2.252738 3.275672\\nC -2.158105 1.296249 3.549986\\nC -1.672103 0.037126 3.629515\\nS 0.029873 0.017491 3.360331\\nH -2.193350 -0.885148 3.811704\\nH -3.209804 1.532983 3.679978\\nH -1.362224 3.304448 3.186158\\nH 1.649822 3.072952 3.672957\\nH 1.211653 3.063496 1.948052\\nN 2.459782 2.810360 -0.250637\\nC 3.702038 3.494473 -0.007019\\nC 3.535455 4.987895 -0.247640\\nN 3.135197 5.227273 -1.629600\\nC 1.880416 4.535567 -1.845563\\nC 2.078667 3.047475 -1.623169\\nH 1.152894 2.506348 -1.839065\\nH 2.851460 2.688628 -2.329274\\nH 1.553070 4.693475 -2.876513\\nH 1.082455 4.876975 -1.160626\\nC 3.080454 6.654114 -1.988537\\nC 2.844320 6.822527 -3.471294\\nC 2.186663 7.952265 -4.018399\\nC 2.020561 8.106371 -5.366127\\nC 2.492133 7.095940 -6.221552\\nC 3.145197 5.989422 -5.714446\\nC 3.348027 5.848597 -4.324291\\nH 3.863749 4.989079 -3.899886\\nH 3.499404 5.200479 -6.367839\\nH 2.373008 7.172394 -7.259107\\nH 1.500989 8.965752 -5.749277\\nH 1.793244 8.745489 -3.332119\\nC 4.379233 7.355133 -1.681520\\nC 5.611944 6.810363 -2.058850\\nC 6.786608 7.485366 -1.790181\\nC 6.790977 8.667525 -1.137467\\nC 5.582928 9.232036 -0.761957\\nC 4.383616 8.627066 -1.012670\\nH 3.493347 9.059701 -0.684797\\nH 5.564907 10.198125 -0.201278\\nH 7.737934 9.148840 -0.891393\\nH 7.716839 6.985883 -2.090130\\nH 5.598264 5.841383 -2.553936\\nH 2.257134 7.157548 -1.438773\\nH 4.471581 5.499686 -0.054850\\nH 2.783282 5.368536 0.473936\\nH 3.991555 3.347332 1.044259\\nH 4.514282 3.107992 -0.648164\\nH 3.270335 0.912568 -0.636794\\nH 0.003857 2.470941 0.018512\\nH -2.123182 1.260043 0.019792\\nH -2.147859 -1.223776 0.010993\\n\",\"xyz\");\n\tviewergrid_17465448883622317[0][5].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2}, \"sphere\": {\"scale\": 0.2}});\n\tviewergrid_17465448883622317[0][0].zoomTo();\n\tviewergrid_17465448883622317[0][1].zoomTo();\n\tviewergrid_17465448883622317[0][2].zoomTo();\n\tviewergrid_17465448883622317[0][3].zoomTo();\n\tviewergrid_17465448883622317[0][4].zoomTo();\n\tviewergrid_17465448883622317[0][5].zoomTo();\n\tviewergrid_17465448883622317[0][0].zoom(0.9);\n\tviewergrid_17465448883622317[0][1].zoom(0.9);\n\tviewergrid_17465448883622317[0][2].zoom(0.9);\n\tviewergrid_17465448883622317[0][3].zoom(0.9);\n\tviewergrid_17465448883622317[0][4].zoom(0.9);\n\tviewergrid_17465448883622317[0][5].zoom(0.9);\nviewergrid_17465448883622317[0][5].render();\nviewergrid_17465448883622317[0][4].render();\nviewergrid_17465448883622317[0][3].render();\nviewergrid_17465448883622317[0][2].render();\nviewergrid_17465448883622317[0][1].render();\nviewergrid_17465448883622317[0][0].render();\n});\n</script>",
      "text/html": [
       "<div id=\"3dmolviewer_17465448883622317\"  style=\"position: relative; width: 4200px; height: 700px;\">\n",
       "        <p id=\"3dmolwarning_17465448883622317\" style=\"background-color:#ffcccc;color:black\">3Dmol.js failed to load for some reason.  Please check your browser console for error messages.<br></p>\n",
       "        </div>\n",
       "<script>\n",
       "\n",
       "var loadScriptAsync = function(uri){\n",
       "  return new Promise((resolve, reject) => {\n",
       "    //this is to ignore the existence of requirejs amd\n",
       "    var savedexports, savedmodule;\n",
       "    if (typeof exports !== 'undefined') savedexports = exports;\n",
       "    else exports = {}\n",
       "    if (typeof module !== 'undefined') savedmodule = module;\n",
       "    else module = {}\n",
       "\n",
       "    var tag = document.createElement('script');\n",
       "    tag.src = uri;\n",
       "    tag.async = true;\n",
       "    tag.onload = () => {\n",
       "        exports = savedexports;\n",
       "        module = savedmodule;\n",
       "        resolve();\n",
       "    };\n",
       "  var firstScriptTag = document.getElementsByTagName('script')[0];\n",
       "  firstScriptTag.parentNode.insertBefore(tag, firstScriptTag);\n",
       "});\n",
       "};\n",
       "\n",
       "if(typeof $3Dmolpromise === 'undefined') {\n",
       "$3Dmolpromise = null;\n",
       "  $3Dmolpromise = loadScriptAsync('XXXX');\n",
       "}\n",
       "\n",
       "var viewer_17465448883622317 = null;\n",
       "var warn = document.getElementById(\"3dmolwarning_17465448883622317\");\n",
       "if(warn) {\n",
       "    warn.parentNode.removeChild(warn);\n",
       "}\n",
       "$3Dmolpromise.then(function() {\n",
       "var viewergrid_17465448883622317 = null;\n",
       "viewergrid_17465448883622317 = $3Dmol.createViewerGrid(document.getElementById(\"3dmolviewer_17465448883622317\"),{rows: 1, cols: 6, control_all: true},{backgroundColor:\"white\"});\n",
       "viewer_17465448883622317 = viewergrid_17465448883622317[0][0];\n",
       "viewergrid_17465448883622317[0][0].zoomTo();viewergrid_17465448883622317[0][1].zoomTo();viewergrid_17465448883622317[0][2].zoomTo();viewergrid_17465448883622317[0][3].zoomTo();viewergrid_17465448883622317[0][4].zoomTo();viewergrid_17465448883622317[0][5].zoomTo();\tviewergrid_17465448883622317[0][0].rotate(180,{\"x\": 0, \"y\": 1});\n",
       "\tviewergrid_17465448883622317[0][1].rotate(180,{\"x\": 0, \"y\": 1});\n",
       "\tviewergrid_17465448883622317[0][2].rotate(180,{\"x\": 0, \"y\": 1});\n",
       "\tviewergrid_17465448883622317[0][3].rotate(180,{\"x\": 0, \"y\": 1});\n",
       "\tviewergrid_17465448883622317[0][4].rotate(180,{\"x\": 0, \"y\": 1});\n",
       "\tviewergrid_17465448883622317[0][5].rotate(180,{\"x\": 0, \"y\": 1});\n",
       "\tviewergrid_17465448883622317[0][0].translate(50,0);\n",
       "\tviewergrid_17465448883622317[0][1].translate(50,0);\n",
       "\tviewergrid_17465448883622317[0][2].translate(50,0);\n",
       "\tviewergrid_17465448883622317[0][3].translate(50,0);\n",
       "\tviewergrid_17465448883622317[0][4].translate(50,0);\n",
       "\tviewergrid_17465448883622317[0][5].translate(50,0);\n",
       "\tviewergrid_17465448883622317[0][0].addModel(\"6\\n\\nC -1.213100 -0.688400 0.000000\\nC -1.202800 0.706400 0.000100\\nC 0.010400 1.394800 -0.000100\\nC 1.213100 0.688400 0.000000\\nC 1.202800 -0.706300 0.000000\\nC -0.010300 -1.394800 0.000000\\n\",\"xyz\");\n",
       "\tviewergrid_17465448883622317[0][0].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}, \"sphere\": {\"scale\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}});\n",
       "\tviewergrid_17465448883622317[0][0].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][1].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][2].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][3].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][4].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][5].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][0].addModel(\"30\\n\\nC -1.213100 -0.688400 0.000000\\nC -1.202800 0.706400 0.000100\\nC 0.010400 1.394800 -0.000100\\nC 1.213100 0.688400 0.000000\\nC 1.202800 -0.706300 0.000000\\nC -0.010300 -1.394800 0.000000\\nH -0.018030 -2.474138 0.004776\\nH 2.135739 -1.244931 0.004688\\nC 2.539399 1.421936 0.025036\\nC 2.982591 1.474046 1.430418\\nN 3.921240 0.758457 2.006648\\nN 3.900221 1.042952 3.317332\\nC 2.944724 1.909171 3.492186\\nC 2.513160 2.500145 4.734679\\nC 3.177326 2.188171 5.904263\\nC 2.747908 2.747484 7.085057\\nC 1.665588 3.603690 7.115953\\nC 0.989325 3.916589 5.927606\\nC 1.426118 3.366275 4.747217\\nH 0.926509 3.611831 3.813351\\nH 0.144391 4.592347 5.923111\\nH 1.335539 4.045459 8.036715\\nH 3.264376 2.524146 8.013174\\nH 4.033709 1.506919 5.880424\\nO 2.339615 2.210736 2.304955\\nH 2.410699 2.436678 -0.359896\\nH 3.273877 0.882054 -0.576789\\nH 0.017550 2.471321 0.003425\\nH -2.125790 1.258959 0.005219\\nH -2.148932 -1.223776 0.010567\\n\",\"xyz\");\n",
       "\tviewergrid_17465448883622317[0][0].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2}, \"sphere\": {\"scale\": 0.2}});\n",
       "\tviewergrid_17465448883622317[0][0].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][1].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][2].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][3].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][4].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][5].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][1].addModel(\"6\\n\\nC -1.213100 -0.688400 0.000000\\nC -1.202800 0.706400 0.000100\\nC 0.010400 1.394800 -0.000100\\nC 1.213100 0.688400 0.000000\\nC 1.202800 -0.706300 0.000000\\nC -0.010300 -1.394800 0.000000\\n\",\"xyz\");\n",
       "\tviewergrid_17465448883622317[0][1].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}, \"sphere\": {\"scale\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}});\n",
       "\tviewergrid_17465448883622317[0][0].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][1].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][2].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][3].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][4].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][5].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][1].addModel(\"36\\n\\nC -1.213100 -0.688400 0.000000\\nC -1.202800 0.706400 0.000100\\nC 0.010400 1.394800 -0.000100\\nC 1.213100 0.688400 0.000000\\nC 1.202800 -0.706300 0.000000\\nC -0.010300 -1.394800 0.000000\\nH -0.004432 -2.478876 0.010198\\nH 2.128450 -1.264063 0.008679\\nC 2.524207 1.443601 -0.027344\\nC 2.652565 2.381227 1.122849\\nN 1.958300 3.427370 1.396010\\nC 2.499694 3.902492 2.540891\\nN 3.501983 3.200059 2.982308\\nO 3.612514 2.190018 2.051783\\nC 2.000316 5.148344 3.194951\\nC 2.342710 5.158673 4.689536\\nC 1.159495 4.752924 5.531057\\nC 0.336425 3.686753 4.823693\\nC -0.311663 4.269026 3.565942\\nC 0.504828 5.395116 2.958313\\nH 0.278725 5.496944 1.899887\\nH 0.266782 6.351463 3.437191\\nH -0.431351 3.469709 2.834886\\nH -1.311631 4.651303 3.798563\\nH -0.425992 3.298613 5.488540\\nH 0.998585 2.844114 4.588436\\nH 1.548324 4.361475 6.488829\\nH 0.554441 5.617014 5.754616\\nH 3.183387 4.461619 4.854927\\nH 2.677376 6.167922 4.998089\\nH 2.516006 5.976359 2.700038\\nH 3.363754 0.752754 -0.005100\\nH 2.572966 2.032949 -0.952056\\nH 0.014265 2.470416 -0.008448\\nH -2.134101 1.262881 0.003624\\nH -2.147239 -1.216597 0.009210\\n\",\"xyz\");\n",
       "\tviewergrid_17465448883622317[0][1].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2}, \"sphere\": {\"scale\": 0.2}});\n",
       "\tviewergrid_17465448883622317[0][0].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][1].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][2].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][3].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][4].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][5].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][2].addModel(\"6\\n\\nC -1.213100 -0.688400 0.000000\\nC -1.202800 0.706400 0.000100\\nC 0.010400 1.394800 -0.000100\\nC 1.213100 0.688400 0.000000\\nC 1.202800 -0.706300 0.000000\\nC -0.010300 -1.394800 0.000000\\n\",\"xyz\");\n",
       "\tviewergrid_17465448883622317[0][2].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}, \"sphere\": {\"scale\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}});\n",
       "\tviewergrid_17465448883622317[0][0].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][1].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][2].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][3].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][4].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][5].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][2].addModel(\"41\\n\\nC -1.213100 -0.688400 0.000000\\nC -1.202800 0.706400 0.000100\\nC 0.010400 1.394800 -0.000100\\nC 1.213100 0.688400 0.000000\\nC 1.202800 -0.706300 0.000000\\nC -0.010300 -1.394800 0.000000\\nH -0.002209 -2.467011 -0.000866\\nH 2.129423 -1.238221 -0.016465\\nC 2.525495 1.435942 -0.036208\\nH 2.404378 2.439462 0.339938\\nH 2.922409 1.466878 -1.053498\\nS 3.852471 0.632562 0.943249\\nC 3.422229 1.139699 2.619128\\nC 2.889325 0.057973 3.527455\\nC 1.555884 -0.597148 3.110142\\nC 0.431508 0.343283 3.193823\\nN -0.436905 1.084121 3.304483\\nC 1.279855 -1.798709 3.984837\\nN 1.338488 -2.983134 3.461296\\nC 1.112037 -4.063070 4.226259\\nC 1.164831 -5.345672 3.642859\\nC 0.939642 -6.465506 4.424317\\nC 0.621551 -6.345369 5.772864\\nC 0.567314 -5.120112 6.364498\\nC 0.799135 -3.946705 5.609543\\nC 0.750651 -2.647716 6.163056\\nC 0.983341 -1.582166 5.353107\\nH 0.940459 -0.548325 5.721911\\nH 0.528158 -2.510288 7.209302\\nH 0.348045 -5.046422 7.417346\\nH 0.465641 -7.242256 6.329447\\nH 0.966264 -7.425663 3.951787\\nH 1.373779 -5.398890 2.590406\\nH 1.623735 -0.914649 2.055014\\nH 3.605971 -0.763221 3.618250\\nH 2.775626 0.491409 4.513928\\nH 4.359272 1.510460 3.031120\\nH 2.705852 1.966765 2.542784\\nH 0.019642 2.475830 -0.002567\\nH -2.139742 1.248878 0.019417\\nH -2.150690 -1.230321 0.005752\\n\",\"xyz\");\n",
       "\tviewergrid_17465448883622317[0][2].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2}, \"sphere\": {\"scale\": 0.2}});\n",
       "\tviewergrid_17465448883622317[0][0].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][1].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][2].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][3].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][4].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][5].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][3].addModel(\"6\\n\\nC -1.213100 -0.688400 0.000000\\nC -1.202800 0.706400 0.000100\\nC 0.010400 1.394800 -0.000100\\nC 1.213100 0.688400 0.000000\\nC 1.202800 -0.706300 0.000000\\nC -0.010300 -1.394800 0.000000\\n\",\"xyz\");\n",
       "\tviewergrid_17465448883622317[0][3].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}, \"sphere\": {\"scale\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}});\n",
       "\tviewergrid_17465448883622317[0][0].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][1].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][2].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][3].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][4].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][5].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][3].addModel(\"33\\n\\nC -1.213100 -0.688400 0.000000\\nC -1.202800 0.706400 0.000100\\nC 0.010400 1.394800 -0.000100\\nC 1.213100 0.688400 0.000000\\nC 1.202800 -0.706300 0.000000\\nC -0.010300 -1.394800 0.000000\\nH -0.020136 -2.469465 0.006182\\nH 2.141659 -1.239948 -0.001089\\nC 2.525527 1.431479 -0.010126\\nN 3.464923 0.784829 0.889917\\nC 3.189960 0.798428 2.237596\\nN 2.108095 1.309025 2.653073\\nC 1.687161 1.185786 4.020471\\nC 1.438091 -0.274989 4.434271\\nC 2.722459 -1.033167 4.782829\\nC 3.659682 -1.241346 3.598991\\nH 3.130458 -1.747115 2.793043\\nC 4.270917 0.060010 3.094207\\nH 5.158171 -0.138792 2.505382\\nH 4.543060 0.683460 3.945659\\nH 4.471629 -1.917307 3.909241\\nH 2.437603 -2.003519 5.181113\\nH 3.255847 -0.489712 5.567626\\nH 0.919072 -0.792544 3.641392\\nH 0.788466 -0.280447 5.321832\\nH 0.745746 1.720924 4.093947\\nH 2.421556 1.648989 4.709040\\nH 4.423568 0.789190 0.623981\\nH 2.964961 1.412726 -1.008852\\nH 2.343503 2.472413 0.303002\\nH 0.020634 2.468597 0.013091\\nH -2.133054 1.251712 0.005452\\nH -2.149838 -1.219854 -0.002360\\n\",\"xyz\");\n",
       "\tviewergrid_17465448883622317[0][3].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2}, \"sphere\": {\"scale\": 0.2}});\n",
       "\tviewergrid_17465448883622317[0][0].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][1].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][2].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][3].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][4].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][5].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][4].addModel(\"6\\n\\nC -1.213100 -0.688400 0.000000\\nC -1.202800 0.706400 0.000100\\nC 0.010400 1.394800 -0.000100\\nC 1.213100 0.688400 0.000000\\nC 1.202800 -0.706300 0.000000\\nC -0.010300 -1.394800 0.000000\\n\",\"xyz\");\n",
       "\tviewergrid_17465448883622317[0][4].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}, \"sphere\": {\"scale\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}});\n",
       "\tviewergrid_17465448883622317[0][0].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][1].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][2].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][3].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][4].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][5].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][4].addModel(\"24\\n\\nC -1.213100 -0.688400 0.000000\\nC -1.202800 0.706400 0.000100\\nC 0.010400 1.394800 -0.000100\\nC 1.213100 0.688400 0.000000\\nC 1.202800 -0.706300 0.000000\\nC -0.010300 -1.394800 0.000000\\nH -0.006029 -2.475557 0.007452\\nH 2.143007 -1.236458 0.001897\\nO 2.413582 1.361001 0.033327\\nC 2.862876 1.865870 -1.229546\\nC 1.863181 2.750107 -1.883521\\nN 1.121395 2.445928 -2.910869\\nC 0.334191 3.531970 -3.070861\\nN 0.562489 4.470629 -2.204864\\nN 1.542811 3.972167 -1.437933\\nH 1.888711 4.496434 -0.637295\\nN -0.560955 3.648972 -4.092463\\nH -1.278650 4.350892 -3.968868\\nH -0.863323 2.763223 -4.496794\\nH 3.086230 1.034333 -1.921013\\nH 3.807772 2.413815 -1.016483\\nH 0.015809 2.477149 0.012909\\nH -2.126117 1.273269 -0.012349\\nH -2.148573 -1.217052 -0.000857\\n\",\"xyz\");\n",
       "\tviewergrid_17465448883622317[0][4].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2}, \"sphere\": {\"scale\": 0.2}});\n",
       "\tviewergrid_17465448883622317[0][0].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][1].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][2].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][3].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][4].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][5].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][5].addModel(\"6\\n\\nC -1.213100 -0.688400 0.000000\\nC -1.202800 0.706400 0.000100\\nC 0.010400 1.394800 -0.000100\\nC 1.213100 0.688400 0.000000\\nC 1.202800 -0.706300 0.000000\\nC -0.010300 -1.394800 0.000000\\n\",\"xyz\");\n",
       "\tviewergrid_17465448883622317[0][5].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}, \"sphere\": {\"scale\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}});\n",
       "\tviewergrid_17465448883622317[0][0].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][1].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][2].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][3].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][4].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][5].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][5].addModel(\"67\\n\\nC -1.213100 -0.688400 0.000000\\nC -1.202800 0.706400 0.000100\\nC 0.010400 1.394800 -0.000100\\nC 1.213100 0.688400 0.000000\\nC 1.202800 -0.706300 0.000000\\nC -0.010300 -1.394800 0.000000\\nH -0.006453 -2.470997 0.003944\\nH 2.127469 -1.240785 0.013119\\nC 2.546854 1.399566 0.045150\\nC 3.031306 1.130175 1.433987\\nN 4.015076 0.318734 1.748731\\nN 4.046648 0.245220 3.067031\\nN 3.145060 0.947771 3.599599\\nN 2.455612 1.546585 2.601681\\nC 1.355788 2.434855 2.838260\\nC 0.070767 1.706601 3.135583\\nC -1.172791 2.252738 3.275672\\nC -2.158105 1.296249 3.549986\\nC -1.672103 0.037126 3.629515\\nS 0.029873 0.017491 3.360331\\nH -2.193350 -0.885148 3.811704\\nH -3.209804 1.532983 3.679978\\nH -1.362224 3.304448 3.186158\\nH 1.649822 3.072952 3.672957\\nH 1.211653 3.063496 1.948052\\nN 2.459782 2.810360 -0.250637\\nC 3.702038 3.494473 -0.007019\\nC 3.535455 4.987895 -0.247640\\nN 3.135197 5.227273 -1.629600\\nC 1.880416 4.535567 -1.845563\\nC 2.078667 3.047475 -1.623169\\nH 1.152894 2.506348 -1.839065\\nH 2.851460 2.688628 -2.329274\\nH 1.553070 4.693475 -2.876513\\nH 1.082455 4.876975 -1.160626\\nC 3.080454 6.654114 -1.988537\\nC 2.844320 6.822527 -3.471294\\nC 2.186663 7.952265 -4.018399\\nC 2.020561 8.106371 -5.366127\\nC 2.492133 7.095940 -6.221552\\nC 3.145197 5.989422 -5.714446\\nC 3.348027 5.848597 -4.324291\\nH 3.863749 4.989079 -3.899886\\nH 3.499404 5.200479 -6.367839\\nH 2.373008 7.172394 -7.259107\\nH 1.500989 8.965752 -5.749277\\nH 1.793244 8.745489 -3.332119\\nC 4.379233 7.355133 -1.681520\\nC 5.611944 6.810363 -2.058850\\nC 6.786608 7.485366 -1.790181\\nC 6.790977 8.667525 -1.137467\\nC 5.582928 9.232036 -0.761957\\nC 4.383616 8.627066 -1.012670\\nH 3.493347 9.059701 -0.684797\\nH 5.564907 10.198125 -0.201278\\nH 7.737934 9.148840 -0.891393\\nH 7.716839 6.985883 -2.090130\\nH 5.598264 5.841383 -2.553936\\nH 2.257134 7.157548 -1.438773\\nH 4.471581 5.499686 -0.054850\\nH 2.783282 5.368536 0.473936\\nH 3.991555 3.347332 1.044259\\nH 4.514282 3.107992 -0.648164\\nH 3.270335 0.912568 -0.636794\\nH 0.003857 2.470941 0.018512\\nH -2.123182 1.260043 0.019792\\nH -2.147859 -1.223776 0.010993\\n\",\"xyz\");\n",
       "\tviewergrid_17465448883622317[0][5].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2}, \"sphere\": {\"scale\": 0.2}});\n",
       "\tviewergrid_17465448883622317[0][0].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][1].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][2].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][3].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][4].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][5].zoomTo();\n",
       "\tviewergrid_17465448883622317[0][0].zoom(0.9);\n",
       "\tviewergrid_17465448883622317[0][1].zoom(0.9);\n",
       "\tviewergrid_17465448883622317[0][2].zoom(0.9);\n",
       "\tviewergrid_17465448883622317[0][3].zoom(0.9);\n",
       "\tviewergrid_17465448883622317[0][4].zoom(0.9);\n",
       "\tviewergrid_17465448883622317[0][5].zoom(0.9);\n",
       "viewergrid_17465448883622317[0][5].render();\n",
       "viewergrid_17465448883622317[0][4].render();\n",
       "viewergrid_17465448883622317[0][3].render();\n",
       "viewergrid_17465448883622317[0][2].render();\n",
       "viewergrid_17465448883622317[0][1].render();\n",
       "viewergrid_17465448883622317[0][0].render();\n",
       "});\n",
       "</script>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "a,x = parse_xyz(\"benzene.xyz\")\n",
    "out = torch.load(\"benzene.pt\", weights_only=False)\n",
    "\n",
    "res = 700\n",
    "view = py3Dmol.view(width=res*6, height=res, viewergrid=(1, 6))\n",
    "view.rotate(180, {'x': 0, 'y': 1})\n",
    "view.translate(50, 0)\n",
    "for i in range(6):\n",
    "    M = out[0][i]\n",
    "    view = Molecule(a, x).show(view=view, viewer=(0, i), zoom=True, color=\"cyan\", opacity=0.6)\n",
    "    view = M.show(view=view, viewer=(0, i), zoom=True)\n",
    "view.zoom(0.9)\n",
    "view.show()\n",
    "make_html(view, \"benzene.html\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 30%|██▉       | 53/178 [00:21<00:51,  2.41it/s]\n"
     ]
    }
   ],
   "source": [
    "a,x = parse_xyz(\"124triazole.xyz\")\n",
    "x = x + torch.tensor([-2, -2, 0.0])\n",
    "\n",
    "out = model.generate(6, prefix=(a, x), **kwargs)\n",
    "torch.save(out, \"124triazole.pt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/3dmoljs_load.v0": "<div id=\"3dmolviewer_17465447455522041\"  style=\"position: relative; width: 4200px; height: 700px;\">\n        <p id=\"3dmolwarning_17465447455522041\" style=\"background-color:#ffcccc;color:black\">3Dmol.js failed to load for some reason.  Please check your browser console for error messages.<br></p>\n        </div>\n<script>\n\nvar loadScriptAsync = function(uri){\n  return new Promise((resolve, reject) => {\n    //this is to ignore the existence of requirejs amd\n    var savedexports, savedmodule;\n    if (typeof exports !== 'undefined') savedexports = exports;\n    else exports = {}\n    if (typeof module !== 'undefined') savedmodule = module;\n    else module = {}\n\n    var tag = document.createElement('script');\n    tag.src = uri;\n    tag.async = true;\n    tag.onload = () => {\n        exports = savedexports;\n        module = savedmodule;\n        resolve();\n    };\n  var firstScriptTag = document.getElementsByTagName('script')[0];\n  firstScriptTag.parentNode.insertBefore(tag, firstScriptTag);\n});\n};\n\nif(typeof $3Dmolpromise === 'undefined') {\n$3Dmolpromise = null;\n  $3Dmolpromise = loadScriptAsync('XXXX');\n}\n\nvar viewer_17465447455522041 = null;\nvar warn = document.getElementById(\"3dmolwarning_17465447455522041\");\nif(warn) {\n    warn.parentNode.removeChild(warn);\n}\n$3Dmolpromise.then(function() {\nvar viewergrid_17465447455522041 = null;\nviewergrid_17465447455522041 = $3Dmol.createViewerGrid(document.getElementById(\"3dmolviewer_17465447455522041\"),{rows: 1, cols: 6, control_all: true},{backgroundColor:\"white\"});\nviewer_17465447455522041 = viewergrid_17465447455522041[0][0];\nviewergrid_17465447455522041[0][0].zoomTo();viewergrid_17465447455522041[0][1].zoomTo();viewergrid_17465447455522041[0][2].zoomTo();viewergrid_17465447455522041[0][3].zoomTo();viewergrid_17465447455522041[0][4].zoomTo();viewergrid_17465447455522041[0][5].zoomTo();\tviewergrid_17465447455522041[0][0].rotate(180,{\"x\": 0, \"y\": 1});\n\tviewergrid_17465447455522041[0][1].rotate(180,{\"x\": 0, \"y\": 1});\n\tviewergrid_17465447455522041[0][2].rotate(180,{\"x\": 0, \"y\": 1});\n\tviewergrid_17465447455522041[0][3].rotate(180,{\"x\": 0, \"y\": 1});\n\tviewergrid_17465447455522041[0][4].rotate(180,{\"x\": 0, \"y\": 1});\n\tviewergrid_17465447455522041[0][5].rotate(180,{\"x\": 0, \"y\": 1});\n\tviewergrid_17465447455522041[0][0].translate(50,0);\n\tviewergrid_17465447455522041[0][1].translate(50,0);\n\tviewergrid_17465447455522041[0][2].translate(50,0);\n\tviewergrid_17465447455522041[0][3].translate(50,0);\n\tviewergrid_17465447455522041[0][4].translate(50,0);\n\tviewergrid_17465447455522041[0][5].translate(50,0);\n\tviewergrid_17465447455522041[0][0].addModel(\"5\\n\\nC -2.799100 -1.201900 -0.000100\\nN -1.449100 -1.036100 0.000000\\nN -0.814800 -2.218300 0.000100\\nC -1.850000 -3.060900 -0.000200\\nN -3.087000 -2.482700 0.000200\\n\",\"xyz\");\n\tviewergrid_17465447455522041[0][0].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}, \"sphere\": {\"scale\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}});\n\tviewergrid_17465447455522041[0][0].zoomTo();\n\tviewergrid_17465447455522041[0][1].zoomTo();\n\tviewergrid_17465447455522041[0][2].zoomTo();\n\tviewergrid_17465447455522041[0][3].zoomTo();\n\tviewergrid_17465447455522041[0][4].zoomTo();\n\tviewergrid_17465447455522041[0][5].zoomTo();\n\tviewergrid_17465447455522041[0][0].addModel(\"42\\n\\nC -2.799100 -1.201900 -0.000100\\nN -1.449100 -1.036100 0.000000\\nN -0.814800 -2.218300 0.000100\\nC -1.850000 -3.060900 -0.000200\\nN -3.087000 -2.482700 0.000200\\nH -1.726573 -4.094086 0.008727\\nC 0.621948 -2.357261 0.036587\\nH 0.849692 -3.422269 0.120938\\nC 1.311689 -1.596901 1.180567\\nO 2.265625 -2.091223 1.767669\\nC 0.777428 -0.267688 1.502048\\nC 0.718320 0.683624 0.507832\\nC 0.177121 1.939409 0.782819\\nC -0.359089 2.222237 2.041442\\nC -0.294143 1.263390 3.039125\\nC 0.291737 0.028645 2.790082\\nH 0.369734 -0.720479 3.555226\\nH -0.692433 1.473516 4.012767\\nH -0.799906 3.176379 2.228058\\nC 0.148641 2.912560 -0.264106\\nC 0.110025 3.743535 -1.132110\\nC 0.066922 4.702864 -2.225329\\nC -1.377639 5.185482 -2.430634\\nC -1.858606 5.994101 -1.219578\\nC -0.926874 7.158141 -0.970738\\nC 0.512676 6.674979 -0.738227\\nC 1.004818 5.878847 -1.937965\\nH 1.005006 6.521070 -2.840217\\nH 2.015064 5.521515 -1.777745\\nH 1.167657 7.544690 -0.588896\\nH 0.565316 6.062321 0.174680\\nH -1.259222 7.743376 -0.080525\\nH -0.934906 7.838788 -1.833495\\nH -2.854048 6.364101 -1.384458\\nH -1.864913 5.347595 -0.347161\\nH -2.044501 4.327087 -2.585057\\nH -1.398884 5.803207 -3.335340\\nO 0.587372 4.147706 -3.405483\\nH 0.112719 3.342823 -3.630335\\nH 1.110940 0.504305 -0.489565\\nH 1.028682 -1.984562 -0.910626\\nH -3.436149 -0.358142 -0.090060\\n\",\"xyz\");\n\tviewergrid_17465447455522041[0][0].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2}, \"sphere\": {\"scale\": 0.2}});\n\tviewergrid_17465447455522041[0][0].zoomTo();\n\tviewergrid_17465447455522041[0][1].zoomTo();\n\tviewergrid_17465447455522041[0][2].zoomTo();\n\tviewergrid_17465447455522041[0][3].zoomTo();\n\tviewergrid_17465447455522041[0][4].zoomTo();\n\tviewergrid_17465447455522041[0][5].zoomTo();\n\tviewergrid_17465447455522041[0][1].addModel(\"5\\n\\nC -2.799100 -1.201900 -0.000100\\nN -1.449100 -1.036100 0.000000\\nN -0.814800 -2.218300 0.000100\\nC -1.850000 -3.060900 -0.000200\\nN -3.087000 -2.482700 0.000200\\n\",\"xyz\");\n\tviewergrid_17465447455522041[0][1].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}, \"sphere\": {\"scale\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}});\n\tviewergrid_17465447455522041[0][0].zoomTo();\n\tviewergrid_17465447455522041[0][1].zoomTo();\n\tviewergrid_17465447455522041[0][2].zoomTo();\n\tviewergrid_17465447455522041[0][3].zoomTo();\n\tviewergrid_17465447455522041[0][4].zoomTo();\n\tviewergrid_17465447455522041[0][5].zoomTo();\n\tviewergrid_17465447455522041[0][1].addModel(\"38\\n\\nC -2.799100 -1.201900 -0.000100\\nN -1.449100 -1.036100 0.000000\\nN -0.814800 -2.218300 0.000100\\nC -1.850000 -3.060900 -0.000200\\nN -3.087000 -2.482700 0.000200\\nH -1.735084 -4.099697 -0.016052\\nC 0.630386 -2.362549 0.041706\\nH 0.826941 -3.333249 0.500636\\nC 1.310374 -2.318484 -1.342072\\nH 0.968565 -3.181934 -1.935838\\nC 1.044821 -1.032607 -2.158056\\nC 1.596835 0.237812 -1.494195\\nO 1.507925 1.378058 -2.339140\\nC 0.260235 1.939590 -2.530220\\nC -0.905800 1.571108 -1.844662\\nC -2.090939 2.243257 -2.143446\\nC -2.126898 3.247004 -3.086152\\nC -0.965130 3.612720 -3.749627\\nC 0.228930 2.959404 -3.468875\\nH 1.135427 3.228182 -3.988422\\nH -0.988973 4.391120 -4.491844\\nC -3.522459 3.785127 -3.220941\\nH -3.593984 4.733143 -2.670558\\nH -3.801935 3.963018 -4.261251\\nC -4.391567 2.691152 -2.553491\\nH -4.706475 1.971586 -3.306818\\nH -5.284256 3.122473 -2.082087\\nC -3.458212 2.008476 -1.526938\\nH -3.517056 2.501037 -0.553149\\nH -3.689840 0.954492 -1.387416\\nH -0.932147 0.794301 -1.094973\\nH 1.082814 0.433063 -0.538183\\nH 2.667379 0.134613 -1.308629\\nH -0.025669 -0.916480 -2.333513\\nH 1.534168 -1.131799 -3.140088\\nH 2.389355 -2.426026 -1.172668\\nH 1.003259 -1.562675 0.672155\\nH -3.453428 -0.342734 0.000296\\n\",\"xyz\");\n\tviewergrid_17465447455522041[0][1].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2}, \"sphere\": {\"scale\": 0.2}});\n\tviewergrid_17465447455522041[0][0].zoomTo();\n\tviewergrid_17465447455522041[0][1].zoomTo();\n\tviewergrid_17465447455522041[0][2].zoomTo();\n\tviewergrid_17465447455522041[0][3].zoomTo();\n\tviewergrid_17465447455522041[0][4].zoomTo();\n\tviewergrid_17465447455522041[0][5].zoomTo();\n\tviewergrid_17465447455522041[0][2].addModel(\"5\\n\\nC -2.799100 -1.201900 -0.000100\\nN -1.449100 -1.036100 0.000000\\nN -0.814800 -2.218300 0.000100\\nC -1.850000 -3.060900 -0.000200\\nN -3.087000 -2.482700 0.000200\\n\",\"xyz\");\n\tviewergrid_17465447455522041[0][2].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}, \"sphere\": {\"scale\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}});\n\tviewergrid_17465447455522041[0][0].zoomTo();\n\tviewergrid_17465447455522041[0][1].zoomTo();\n\tviewergrid_17465447455522041[0][2].zoomTo();\n\tviewergrid_17465447455522041[0][3].zoomTo();\n\tviewergrid_17465447455522041[0][4].zoomTo();\n\tviewergrid_17465447455522041[0][5].zoomTo();\n\tviewergrid_17465447455522041[0][2].addModel(\"58\\n\\nC -2.799100 -1.201900 -0.000100\\nN -1.449100 -1.036100 0.000000\\nN -0.814800 -2.218300 0.000100\\nC -1.850000 -3.060900 -0.000200\\nN -3.087000 -2.482700 0.000200\\nH -1.749046 -4.127399 -0.018371\\nC 0.594408 -2.367259 -0.000584\\nH 0.818574 -3.416152 -0.180257\\nC 1.305974 -1.518819 -1.102497\\nO 1.574410 -1.997737 -2.175487\\nN 1.621283 -0.237708 -0.763512\\nC 1.304239 0.354994 0.489971\\nC 0.284906 1.274009 0.597860\\nC -0.026788 1.814239 1.856470\\nC -1.066840 2.765441 2.044186\\nC -1.334999 3.268699 3.273908\\nC -0.585995 2.878602 4.386980\\nC 0.429445 1.958133 4.246751\\nC 0.739264 1.403082 2.981747\\nC 1.787424 0.480111 2.828878\\nC 2.078005 -0.033483 1.601531\\nH 2.897939 -0.725436 1.471225\\nH 2.350769 0.183051 3.696366\\nH 1.007071 1.656434 5.090866\\nH -0.805502 3.311283 5.353349\\nH -2.122069 4.002041 3.398118\\nH -1.657008 3.073291 1.172479\\nH -0.294230 1.576672 -0.259848\\nC 2.453919 0.572354 -1.653335\\nH 3.377913 0.824298 -1.137931\\nH 2.682044 -0.052018 -2.539329\\nC 1.744966 1.856669 -2.114143\\nO 2.286403 2.934350 -2.086871\\nN 0.468596 1.634214 -2.543116\\nH 0.093674 0.714062 -2.572768\\nC -0.396418 2.719615 -2.993256\\nH 0.255978 3.593400 -3.112423\\nH -1.141186 2.924448 -2.225568\\nC -1.093877 2.360320 -4.311166\\nC -1.951815 1.135605 -4.165790\\nC -1.504476 -0.061533 -4.509633\\nC -2.293064 -1.314516 -4.364396\\nC -3.756129 -1.042343 -4.072364\\nC -3.890762 0.088824 -3.067421\\nC -3.306484 1.376041 -3.659257\\nH -3.301906 2.165966 -2.892891\\nH -3.933928 1.728327 -4.480518\\nH -4.932157 0.239050 -2.805775\\nH -3.345669 -0.178618 -2.167499\\nH -4.224554 -1.946613 -3.701379\\nH -4.245940 -0.750272 -5.005791\\nH -2.204052 -1.909531 -5.279084\\nH -1.858669 -1.911313 -3.544058\\nH -0.512381 -0.169618 -4.930179\\nH -0.328973 2.193717 -5.080121\\nH -1.706908 3.213839 -4.623670\\nH 0.995869 -2.134341 0.991362\\nH -3.409816 -0.330194 0.026342\\n\",\"xyz\");\n\tviewergrid_17465447455522041[0][2].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2}, \"sphere\": {\"scale\": 0.2}});\n\tviewergrid_17465447455522041[0][0].zoomTo();\n\tviewergrid_17465447455522041[0][1].zoomTo();\n\tviewergrid_17465447455522041[0][2].zoomTo();\n\tviewergrid_17465447455522041[0][3].zoomTo();\n\tviewergrid_17465447455522041[0][4].zoomTo();\n\tviewergrid_17465447455522041[0][5].zoomTo();\n\tviewergrid_17465447455522041[0][3].addModel(\"5\\n\\nC -2.799100 -1.201900 -0.000100\\nN -1.449100 -1.036100 0.000000\\nN -0.814800 -2.218300 0.000100\\nC -1.850000 -3.060900 -0.000200\\nN -3.087000 -2.482700 0.000200\\n\",\"xyz\");\n\tviewergrid_17465447455522041[0][3].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}, \"sphere\": {\"scale\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}});\n\tviewergrid_17465447455522041[0][0].zoomTo();\n\tviewergrid_17465447455522041[0][1].zoomTo();\n\tviewergrid_17465447455522041[0][2].zoomTo();\n\tviewergrid_17465447455522041[0][3].zoomTo();\n\tviewergrid_17465447455522041[0][4].zoomTo();\n\tviewergrid_17465447455522041[0][5].zoomTo();\n\tviewergrid_17465447455522041[0][3].addModel(\"41\\n\\nC -2.799100 -1.201900 -0.000100\\nN -1.449100 -1.036100 0.000000\\nN -0.814800 -2.218300 0.000100\\nC -1.850000 -3.060900 -0.000200\\nN -3.087000 -2.482700 0.000200\\nH -1.762421 -4.104905 -0.002372\\nC 0.619526 -2.409250 0.036594\\nH 0.946819 -2.791229 -0.939353\\nC 1.012154 -3.398622 1.130499\\nH 0.416754 -4.300103 1.026393\\nC 0.812074 -2.817443 2.531013\\nC 0.528517 -3.931734 3.548101\\nO -0.679425 -4.570082 3.225548\\nC -1.850365 -3.843141 3.296380\\nC -2.930282 -4.402685 2.621037\\nC -4.138028 -3.752849 2.602574\\nC -4.318758 -2.548382 3.264261\\nC -3.248971 -1.992250 3.941642\\nC -2.044265 -2.625673 3.964726\\nH -1.212592 -2.176716 4.504933\\nH -3.364764 -1.050257 4.468789\\nC -5.627352 -1.855374 3.216113\\nC -6.215411 -1.365131 4.365512\\nC -7.434099 -0.715104 4.320555\\nC -8.095801 -0.535939 3.118992\\nC -7.530295 -1.003898 1.945922\\nC -6.286136 -1.652558 1.987780\\nH -5.834816 -1.990671 1.094496\\nH -8.042686 -0.873919 1.005323\\nH -9.049232 -0.045180 3.071612\\nH -7.918015 -0.324547 5.221487\\nH -5.725627 -1.506936 5.310627\\nH -4.975245 -4.184286 2.059756\\nH -2.797225 -5.347121 2.113794\\nH 0.514547 -3.554687 4.575103\\nH 1.293030 -4.701756 3.476121\\nH 1.686770 -2.262569 2.844053\\nH -0.033682 -2.124672 2.502224\\nH 2.060493 -3.701384 0.997277\\nH 1.064739 -1.417180 0.209571\\nH -3.456603 -0.342881 0.036313\\n\",\"xyz\");\n\tviewergrid_17465447455522041[0][3].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2}, \"sphere\": {\"scale\": 0.2}});\n\tviewergrid_17465447455522041[0][0].zoomTo();\n\tviewergrid_17465447455522041[0][1].zoomTo();\n\tviewergrid_17465447455522041[0][2].zoomTo();\n\tviewergrid_17465447455522041[0][3].zoomTo();\n\tviewergrid_17465447455522041[0][4].zoomTo();\n\tviewergrid_17465447455522041[0][5].zoomTo();\n\tviewergrid_17465447455522041[0][4].addModel(\"5\\n\\nC -2.799100 -1.201900 -0.000100\\nN -1.449100 -1.036100 0.000000\\nN -0.814800 -2.218300 0.000100\\nC -1.850000 -3.060900 -0.000200\\nN -3.087000 -2.482700 0.000200\\n\",\"xyz\");\n\tviewergrid_17465447455522041[0][4].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}, \"sphere\": {\"scale\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}});\n\tviewergrid_17465447455522041[0][0].zoomTo();\n\tviewergrid_17465447455522041[0][1].zoomTo();\n\tviewergrid_17465447455522041[0][2].zoomTo();\n\tviewergrid_17465447455522041[0][3].zoomTo();\n\tviewergrid_17465447455522041[0][4].zoomTo();\n\tviewergrid_17465447455522041[0][5].zoomTo();\n\tviewergrid_17465447455522041[0][4].addModel(\"41\\n\\nC -2.799100 -1.201900 -0.000100\\nN -1.449100 -1.036100 0.000000\\nN -0.814800 -2.218300 0.000100\\nC -1.850000 -3.060900 -0.000200\\nN -3.087000 -2.482700 0.000200\\nH -1.711847 -4.098308 0.004320\\nC 0.620717 -2.343754 -0.001301\\nH 1.019036 -2.000346 0.955774\\nC 1.281736 -1.529465 -1.133801\\nO 2.572563 -1.121458 -0.802338\\nC 2.722686 -0.045914 0.059691\\nC 1.680835 0.682181 0.613756\\nC 1.976143 1.741304 1.459485\\nC 3.278343 2.087435 1.760642\\nC 4.312913 1.354293 1.208296\\nC 4.048062 0.298817 0.353483\\nH 4.831995 -0.273470 -0.106505\\nH 5.330972 1.604447 1.414271\\nC 3.547152 3.247320 2.686790\\nH 4.575905 3.596501 2.546728\\nH 2.874539 4.068775 2.461885\\nC 3.351366 2.860456 4.172274\\nC 1.882167 2.703971 4.470551\\nC 1.308797 1.446016 4.509246\\nC -0.053173 1.317156 4.760702\\nC -0.828842 2.446767 4.953089\\nC -0.238479 3.704959 4.912427\\nC 1.108961 3.818369 4.672192\\nH 1.566689 4.796432 4.643493\\nH -0.834717 4.590847 5.071500\\nH -1.893170 2.358524 5.159526\\nH -0.504088 0.336530 4.796483\\nH 1.908267 0.566420 4.360384\\nH 3.779027 3.647440 4.793512\\nH 3.886639 1.931688 4.368924\\nH 1.158705 2.312562 1.888492\\nH 0.641225 0.455574 0.409207\\nH 0.668124 -0.669217 -1.394237\\nH 1.393591 -2.153640 -2.014869\\nH 0.860500 -3.401235 -0.108931\\nH -3.447765 -0.367751 -0.013494\\n\",\"xyz\");\n\tviewergrid_17465447455522041[0][4].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2}, \"sphere\": {\"scale\": 0.2}});\n\tviewergrid_17465447455522041[0][0].zoomTo();\n\tviewergrid_17465447455522041[0][1].zoomTo();\n\tviewergrid_17465447455522041[0][2].zoomTo();\n\tviewergrid_17465447455522041[0][3].zoomTo();\n\tviewergrid_17465447455522041[0][4].zoomTo();\n\tviewergrid_17465447455522041[0][5].zoomTo();\n\tviewergrid_17465447455522041[0][5].addModel(\"5\\n\\nC -2.799100 -1.201900 -0.000100\\nN -1.449100 -1.036100 0.000000\\nN -0.814800 -2.218300 0.000100\\nC -1.850000 -3.060900 -0.000200\\nN -3.087000 -2.482700 0.000200\\n\",\"xyz\");\n\tviewergrid_17465447455522041[0][5].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}, \"sphere\": {\"scale\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}});\n\tviewergrid_17465447455522041[0][0].zoomTo();\n\tviewergrid_17465447455522041[0][1].zoomTo();\n\tviewergrid_17465447455522041[0][2].zoomTo();\n\tviewergrid_17465447455522041[0][3].zoomTo();\n\tviewergrid_17465447455522041[0][4].zoomTo();\n\tviewergrid_17465447455522041[0][5].zoomTo();\n\tviewergrid_17465447455522041[0][5].addModel(\"49\\n\\nC -2.799100 -1.201900 -0.000100\\nN -1.449100 -1.036100 0.000000\\nN -0.814800 -2.218300 0.000100\\nC -1.850000 -3.060900 -0.000200\\nN -3.087000 -2.482700 0.000200\\nH -1.749902 -4.142825 -0.017826\\nC 0.627141 -2.355077 -0.026450\\nH 0.889720 -3.275759 0.481916\\nC 1.165053 -2.353167 -1.469546\\nH 2.244127 -2.450148 -1.422976\\nC 0.784439 -1.104223 -2.254291\\nC 1.361102 0.193258 -1.672533\\nO 0.905884 1.325329 -2.394067\\nC -0.338717 1.824163 -2.173792\\nC -1.102051 1.692701 -1.009376\\nC -2.338019 2.289780 -0.915996\\nC -2.841229 3.031131 -1.995585\\nC -2.073092 3.202203 -3.140373\\nC -0.830900 2.593240 -3.225718\\nH -0.222909 2.710805 -4.107958\\nH -2.437979 3.799814 -3.966326\\nC -4.119779 3.628366 -1.899142\\nC -5.198647 4.137827 -1.835868\\nC -6.496937 4.735146 -1.706287\\nC -6.610501 5.918965 -2.677011\\nC -5.574172 7.007582 -2.367330\\nC -5.748822 7.522051 -0.938332\\nC -5.589903 6.371551 0.027243\\nC -6.625757 5.305589 -0.272982\\nH -7.635399 5.711557 -0.173267\\nH -6.536569 4.459565 0.429912\\nH -5.672285 6.724654 1.063329\\nH -4.587306 5.935208 -0.067257\\nH -5.005718 8.294034 -0.733351\\nH -6.714706 7.992824 -0.822777\\nH -5.722057 7.840546 -3.091578\\nH -4.587528 6.589805 -2.505089\\nH -6.467308 5.551594 -3.699138\\nH -7.637864 6.369616 -2.614443\\nH -7.284837 3.959351 -1.948984\\nH -2.934168 2.205671 -0.012930\\nH -0.726271 1.131769 -0.159580\\nH 2.450660 0.208328 -1.795732\\nH 1.141487 0.292493 -0.600904\\nH 1.131384 -1.180782 -3.282395\\nH -0.301686 -1.027418 -2.281593\\nH 0.763443 -3.211558 -1.991412\\nH 1.037087 -1.515012 0.540437\\nH -3.417812 -0.328996 0.005538\\n\",\"xyz\");\n\tviewergrid_17465447455522041[0][5].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2}, \"sphere\": {\"scale\": 0.2}});\n\tviewergrid_17465447455522041[0][0].zoomTo();\n\tviewergrid_17465447455522041[0][1].zoomTo();\n\tviewergrid_17465447455522041[0][2].zoomTo();\n\tviewergrid_17465447455522041[0][3].zoomTo();\n\tviewergrid_17465447455522041[0][4].zoomTo();\n\tviewergrid_17465447455522041[0][5].zoomTo();\n\tviewergrid_17465447455522041[0][0].zoom(0.9);\n\tviewergrid_17465447455522041[0][1].zoom(0.9);\n\tviewergrid_17465447455522041[0][2].zoom(0.9);\n\tviewergrid_17465447455522041[0][3].zoom(0.9);\n\tviewergrid_17465447455522041[0][4].zoom(0.9);\n\tviewergrid_17465447455522041[0][5].zoom(0.9);\nviewergrid_17465447455522041[0][5].render();\nviewergrid_17465447455522041[0][4].render();\nviewergrid_17465447455522041[0][3].render();\nviewergrid_17465447455522041[0][2].render();\nviewergrid_17465447455522041[0][1].render();\nviewergrid_17465447455522041[0][0].render();\n});\n</script>",
      "text/html": [
       "<div id=\"3dmolviewer_17465447455522041\"  style=\"position: relative; width: 4200px; height: 700px;\">\n",
       "        <p id=\"3dmolwarning_17465447455522041\" style=\"background-color:#ffcccc;color:black\">3Dmol.js failed to load for some reason.  Please check your browser console for error messages.<br></p>\n",
       "        </div>\n",
       "<script>\n",
       "\n",
       "var loadScriptAsync = function(uri){\n",
       "  return new Promise((resolve, reject) => {\n",
       "    //this is to ignore the existence of requirejs amd\n",
       "    var savedexports, savedmodule;\n",
       "    if (typeof exports !== 'undefined') savedexports = exports;\n",
       "    else exports = {}\n",
       "    if (typeof module !== 'undefined') savedmodule = module;\n",
       "    else module = {}\n",
       "\n",
       "    var tag = document.createElement('script');\n",
       "    tag.src = uri;\n",
       "    tag.async = true;\n",
       "    tag.onload = () => {\n",
       "        exports = savedexports;\n",
       "        module = savedmodule;\n",
       "        resolve();\n",
       "    };\n",
       "  var firstScriptTag = document.getElementsByTagName('script')[0];\n",
       "  firstScriptTag.parentNode.insertBefore(tag, firstScriptTag);\n",
       "});\n",
       "};\n",
       "\n",
       "if(typeof $3Dmolpromise === 'undefined') {\n",
       "$3Dmolpromise = null;\n",
       "  $3Dmolpromise = loadScriptAsync('XXXX');\n",
       "}\n",
       "\n",
       "var viewer_17465447455522041 = null;\n",
       "var warn = document.getElementById(\"3dmolwarning_17465447455522041\");\n",
       "if(warn) {\n",
       "    warn.parentNode.removeChild(warn);\n",
       "}\n",
       "$3Dmolpromise.then(function() {\n",
       "var viewergrid_17465447455522041 = null;\n",
       "viewergrid_17465447455522041 = $3Dmol.createViewerGrid(document.getElementById(\"3dmolviewer_17465447455522041\"),{rows: 1, cols: 6, control_all: true},{backgroundColor:\"white\"});\n",
       "viewer_17465447455522041 = viewergrid_17465447455522041[0][0];\n",
       "viewergrid_17465447455522041[0][0].zoomTo();viewergrid_17465447455522041[0][1].zoomTo();viewergrid_17465447455522041[0][2].zoomTo();viewergrid_17465447455522041[0][3].zoomTo();viewergrid_17465447455522041[0][4].zoomTo();viewergrid_17465447455522041[0][5].zoomTo();\tviewergrid_17465447455522041[0][0].rotate(180,{\"x\": 0, \"y\": 1});\n",
       "\tviewergrid_17465447455522041[0][1].rotate(180,{\"x\": 0, \"y\": 1});\n",
       "\tviewergrid_17465447455522041[0][2].rotate(180,{\"x\": 0, \"y\": 1});\n",
       "\tviewergrid_17465447455522041[0][3].rotate(180,{\"x\": 0, \"y\": 1});\n",
       "\tviewergrid_17465447455522041[0][4].rotate(180,{\"x\": 0, \"y\": 1});\n",
       "\tviewergrid_17465447455522041[0][5].rotate(180,{\"x\": 0, \"y\": 1});\n",
       "\tviewergrid_17465447455522041[0][0].translate(50,0);\n",
       "\tviewergrid_17465447455522041[0][1].translate(50,0);\n",
       "\tviewergrid_17465447455522041[0][2].translate(50,0);\n",
       "\tviewergrid_17465447455522041[0][3].translate(50,0);\n",
       "\tviewergrid_17465447455522041[0][4].translate(50,0);\n",
       "\tviewergrid_17465447455522041[0][5].translate(50,0);\n",
       "\tviewergrid_17465447455522041[0][0].addModel(\"5\\n\\nC -2.799100 -1.201900 -0.000100\\nN -1.449100 -1.036100 0.000000\\nN -0.814800 -2.218300 0.000100\\nC -1.850000 -3.060900 -0.000200\\nN -3.087000 -2.482700 0.000200\\n\",\"xyz\");\n",
       "\tviewergrid_17465447455522041[0][0].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}, \"sphere\": {\"scale\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}});\n",
       "\tviewergrid_17465447455522041[0][0].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][1].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][2].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][3].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][4].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][5].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][0].addModel(\"42\\n\\nC -2.799100 -1.201900 -0.000100\\nN -1.449100 -1.036100 0.000000\\nN -0.814800 -2.218300 0.000100\\nC -1.850000 -3.060900 -0.000200\\nN -3.087000 -2.482700 0.000200\\nH -1.726573 -4.094086 0.008727\\nC 0.621948 -2.357261 0.036587\\nH 0.849692 -3.422269 0.120938\\nC 1.311689 -1.596901 1.180567\\nO 2.265625 -2.091223 1.767669\\nC 0.777428 -0.267688 1.502048\\nC 0.718320 0.683624 0.507832\\nC 0.177121 1.939409 0.782819\\nC -0.359089 2.222237 2.041442\\nC -0.294143 1.263390 3.039125\\nC 0.291737 0.028645 2.790082\\nH 0.369734 -0.720479 3.555226\\nH -0.692433 1.473516 4.012767\\nH -0.799906 3.176379 2.228058\\nC 0.148641 2.912560 -0.264106\\nC 0.110025 3.743535 -1.132110\\nC 0.066922 4.702864 -2.225329\\nC -1.377639 5.185482 -2.430634\\nC -1.858606 5.994101 -1.219578\\nC -0.926874 7.158141 -0.970738\\nC 0.512676 6.674979 -0.738227\\nC 1.004818 5.878847 -1.937965\\nH 1.005006 6.521070 -2.840217\\nH 2.015064 5.521515 -1.777745\\nH 1.167657 7.544690 -0.588896\\nH 0.565316 6.062321 0.174680\\nH -1.259222 7.743376 -0.080525\\nH -0.934906 7.838788 -1.833495\\nH -2.854048 6.364101 -1.384458\\nH -1.864913 5.347595 -0.347161\\nH -2.044501 4.327087 -2.585057\\nH -1.398884 5.803207 -3.335340\\nO 0.587372 4.147706 -3.405483\\nH 0.112719 3.342823 -3.630335\\nH 1.110940 0.504305 -0.489565\\nH 1.028682 -1.984562 -0.910626\\nH -3.436149 -0.358142 -0.090060\\n\",\"xyz\");\n",
       "\tviewergrid_17465447455522041[0][0].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2}, \"sphere\": {\"scale\": 0.2}});\n",
       "\tviewergrid_17465447455522041[0][0].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][1].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][2].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][3].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][4].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][5].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][1].addModel(\"5\\n\\nC -2.799100 -1.201900 -0.000100\\nN -1.449100 -1.036100 0.000000\\nN -0.814800 -2.218300 0.000100\\nC -1.850000 -3.060900 -0.000200\\nN -3.087000 -2.482700 0.000200\\n\",\"xyz\");\n",
       "\tviewergrid_17465447455522041[0][1].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}, \"sphere\": {\"scale\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}});\n",
       "\tviewergrid_17465447455522041[0][0].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][1].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][2].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][3].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][4].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][5].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][1].addModel(\"38\\n\\nC -2.799100 -1.201900 -0.000100\\nN -1.449100 -1.036100 0.000000\\nN -0.814800 -2.218300 0.000100\\nC -1.850000 -3.060900 -0.000200\\nN -3.087000 -2.482700 0.000200\\nH -1.735084 -4.099697 -0.016052\\nC 0.630386 -2.362549 0.041706\\nH 0.826941 -3.333249 0.500636\\nC 1.310374 -2.318484 -1.342072\\nH 0.968565 -3.181934 -1.935838\\nC 1.044821 -1.032607 -2.158056\\nC 1.596835 0.237812 -1.494195\\nO 1.507925 1.378058 -2.339140\\nC 0.260235 1.939590 -2.530220\\nC -0.905800 1.571108 -1.844662\\nC -2.090939 2.243257 -2.143446\\nC -2.126898 3.247004 -3.086152\\nC -0.965130 3.612720 -3.749627\\nC 0.228930 2.959404 -3.468875\\nH 1.135427 3.228182 -3.988422\\nH -0.988973 4.391120 -4.491844\\nC -3.522459 3.785127 -3.220941\\nH -3.593984 4.733143 -2.670558\\nH -3.801935 3.963018 -4.261251\\nC -4.391567 2.691152 -2.553491\\nH -4.706475 1.971586 -3.306818\\nH -5.284256 3.122473 -2.082087\\nC -3.458212 2.008476 -1.526938\\nH -3.517056 2.501037 -0.553149\\nH -3.689840 0.954492 -1.387416\\nH -0.932147 0.794301 -1.094973\\nH 1.082814 0.433063 -0.538183\\nH 2.667379 0.134613 -1.308629\\nH -0.025669 -0.916480 -2.333513\\nH 1.534168 -1.131799 -3.140088\\nH 2.389355 -2.426026 -1.172668\\nH 1.003259 -1.562675 0.672155\\nH -3.453428 -0.342734 0.000296\\n\",\"xyz\");\n",
       "\tviewergrid_17465447455522041[0][1].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2}, \"sphere\": {\"scale\": 0.2}});\n",
       "\tviewergrid_17465447455522041[0][0].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][1].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][2].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][3].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][4].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][5].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][2].addModel(\"5\\n\\nC -2.799100 -1.201900 -0.000100\\nN -1.449100 -1.036100 0.000000\\nN -0.814800 -2.218300 0.000100\\nC -1.850000 -3.060900 -0.000200\\nN -3.087000 -2.482700 0.000200\\n\",\"xyz\");\n",
       "\tviewergrid_17465447455522041[0][2].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}, \"sphere\": {\"scale\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}});\n",
       "\tviewergrid_17465447455522041[0][0].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][1].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][2].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][3].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][4].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][5].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][2].addModel(\"58\\n\\nC -2.799100 -1.201900 -0.000100\\nN -1.449100 -1.036100 0.000000\\nN -0.814800 -2.218300 0.000100\\nC -1.850000 -3.060900 -0.000200\\nN -3.087000 -2.482700 0.000200\\nH -1.749046 -4.127399 -0.018371\\nC 0.594408 -2.367259 -0.000584\\nH 0.818574 -3.416152 -0.180257\\nC 1.305974 -1.518819 -1.102497\\nO 1.574410 -1.997737 -2.175487\\nN 1.621283 -0.237708 -0.763512\\nC 1.304239 0.354994 0.489971\\nC 0.284906 1.274009 0.597860\\nC -0.026788 1.814239 1.856470\\nC -1.066840 2.765441 2.044186\\nC -1.334999 3.268699 3.273908\\nC -0.585995 2.878602 4.386980\\nC 0.429445 1.958133 4.246751\\nC 0.739264 1.403082 2.981747\\nC 1.787424 0.480111 2.828878\\nC 2.078005 -0.033483 1.601531\\nH 2.897939 -0.725436 1.471225\\nH 2.350769 0.183051 3.696366\\nH 1.007071 1.656434 5.090866\\nH -0.805502 3.311283 5.353349\\nH -2.122069 4.002041 3.398118\\nH -1.657008 3.073291 1.172479\\nH -0.294230 1.576672 -0.259848\\nC 2.453919 0.572354 -1.653335\\nH 3.377913 0.824298 -1.137931\\nH 2.682044 -0.052018 -2.539329\\nC 1.744966 1.856669 -2.114143\\nO 2.286403 2.934350 -2.086871\\nN 0.468596 1.634214 -2.543116\\nH 0.093674 0.714062 -2.572768\\nC -0.396418 2.719615 -2.993256\\nH 0.255978 3.593400 -3.112423\\nH -1.141186 2.924448 -2.225568\\nC -1.093877 2.360320 -4.311166\\nC -1.951815 1.135605 -4.165790\\nC -1.504476 -0.061533 -4.509633\\nC -2.293064 -1.314516 -4.364396\\nC -3.756129 -1.042343 -4.072364\\nC -3.890762 0.088824 -3.067421\\nC -3.306484 1.376041 -3.659257\\nH -3.301906 2.165966 -2.892891\\nH -3.933928 1.728327 -4.480518\\nH -4.932157 0.239050 -2.805775\\nH -3.345669 -0.178618 -2.167499\\nH -4.224554 -1.946613 -3.701379\\nH -4.245940 -0.750272 -5.005791\\nH -2.204052 -1.909531 -5.279084\\nH -1.858669 -1.911313 -3.544058\\nH -0.512381 -0.169618 -4.930179\\nH -0.328973 2.193717 -5.080121\\nH -1.706908 3.213839 -4.623670\\nH 0.995869 -2.134341 0.991362\\nH -3.409816 -0.330194 0.026342\\n\",\"xyz\");\n",
       "\tviewergrid_17465447455522041[0][2].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2}, \"sphere\": {\"scale\": 0.2}});\n",
       "\tviewergrid_17465447455522041[0][0].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][1].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][2].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][3].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][4].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][5].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][3].addModel(\"5\\n\\nC -2.799100 -1.201900 -0.000100\\nN -1.449100 -1.036100 0.000000\\nN -0.814800 -2.218300 0.000100\\nC -1.850000 -3.060900 -0.000200\\nN -3.087000 -2.482700 0.000200\\n\",\"xyz\");\n",
       "\tviewergrid_17465447455522041[0][3].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}, \"sphere\": {\"scale\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}});\n",
       "\tviewergrid_17465447455522041[0][0].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][1].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][2].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][3].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][4].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][5].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][3].addModel(\"41\\n\\nC -2.799100 -1.201900 -0.000100\\nN -1.449100 -1.036100 0.000000\\nN -0.814800 -2.218300 0.000100\\nC -1.850000 -3.060900 -0.000200\\nN -3.087000 -2.482700 0.000200\\nH -1.762421 -4.104905 -0.002372\\nC 0.619526 -2.409250 0.036594\\nH 0.946819 -2.791229 -0.939353\\nC 1.012154 -3.398622 1.130499\\nH 0.416754 -4.300103 1.026393\\nC 0.812074 -2.817443 2.531013\\nC 0.528517 -3.931734 3.548101\\nO -0.679425 -4.570082 3.225548\\nC -1.850365 -3.843141 3.296380\\nC -2.930282 -4.402685 2.621037\\nC -4.138028 -3.752849 2.602574\\nC -4.318758 -2.548382 3.264261\\nC -3.248971 -1.992250 3.941642\\nC -2.044265 -2.625673 3.964726\\nH -1.212592 -2.176716 4.504933\\nH -3.364764 -1.050257 4.468789\\nC -5.627352 -1.855374 3.216113\\nC -6.215411 -1.365131 4.365512\\nC -7.434099 -0.715104 4.320555\\nC -8.095801 -0.535939 3.118992\\nC -7.530295 -1.003898 1.945922\\nC -6.286136 -1.652558 1.987780\\nH -5.834816 -1.990671 1.094496\\nH -8.042686 -0.873919 1.005323\\nH -9.049232 -0.045180 3.071612\\nH -7.918015 -0.324547 5.221487\\nH -5.725627 -1.506936 5.310627\\nH -4.975245 -4.184286 2.059756\\nH -2.797225 -5.347121 2.113794\\nH 0.514547 -3.554687 4.575103\\nH 1.293030 -4.701756 3.476121\\nH 1.686770 -2.262569 2.844053\\nH -0.033682 -2.124672 2.502224\\nH 2.060493 -3.701384 0.997277\\nH 1.064739 -1.417180 0.209571\\nH -3.456603 -0.342881 0.036313\\n\",\"xyz\");\n",
       "\tviewergrid_17465447455522041[0][3].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2}, \"sphere\": {\"scale\": 0.2}});\n",
       "\tviewergrid_17465447455522041[0][0].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][1].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][2].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][3].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][4].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][5].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][4].addModel(\"5\\n\\nC -2.799100 -1.201900 -0.000100\\nN -1.449100 -1.036100 0.000000\\nN -0.814800 -2.218300 0.000100\\nC -1.850000 -3.060900 -0.000200\\nN -3.087000 -2.482700 0.000200\\n\",\"xyz\");\n",
       "\tviewergrid_17465447455522041[0][4].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}, \"sphere\": {\"scale\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}});\n",
       "\tviewergrid_17465447455522041[0][0].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][1].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][2].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][3].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][4].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][5].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][4].addModel(\"41\\n\\nC -2.799100 -1.201900 -0.000100\\nN -1.449100 -1.036100 0.000000\\nN -0.814800 -2.218300 0.000100\\nC -1.850000 -3.060900 -0.000200\\nN -3.087000 -2.482700 0.000200\\nH -1.711847 -4.098308 0.004320\\nC 0.620717 -2.343754 -0.001301\\nH 1.019036 -2.000346 0.955774\\nC 1.281736 -1.529465 -1.133801\\nO 2.572563 -1.121458 -0.802338\\nC 2.722686 -0.045914 0.059691\\nC 1.680835 0.682181 0.613756\\nC 1.976143 1.741304 1.459485\\nC 3.278343 2.087435 1.760642\\nC 4.312913 1.354293 1.208296\\nC 4.048062 0.298817 0.353483\\nH 4.831995 -0.273470 -0.106505\\nH 5.330972 1.604447 1.414271\\nC 3.547152 3.247320 2.686790\\nH 4.575905 3.596501 2.546728\\nH 2.874539 4.068775 2.461885\\nC 3.351366 2.860456 4.172274\\nC 1.882167 2.703971 4.470551\\nC 1.308797 1.446016 4.509246\\nC -0.053173 1.317156 4.760702\\nC -0.828842 2.446767 4.953089\\nC -0.238479 3.704959 4.912427\\nC 1.108961 3.818369 4.672192\\nH 1.566689 4.796432 4.643493\\nH -0.834717 4.590847 5.071500\\nH -1.893170 2.358524 5.159526\\nH -0.504088 0.336530 4.796483\\nH 1.908267 0.566420 4.360384\\nH 3.779027 3.647440 4.793512\\nH 3.886639 1.931688 4.368924\\nH 1.158705 2.312562 1.888492\\nH 0.641225 0.455574 0.409207\\nH 0.668124 -0.669217 -1.394237\\nH 1.393591 -2.153640 -2.014869\\nH 0.860500 -3.401235 -0.108931\\nH -3.447765 -0.367751 -0.013494\\n\",\"xyz\");\n",
       "\tviewergrid_17465447455522041[0][4].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2}, \"sphere\": {\"scale\": 0.2}});\n",
       "\tviewergrid_17465447455522041[0][0].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][1].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][2].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][3].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][4].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][5].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][5].addModel(\"5\\n\\nC -2.799100 -1.201900 -0.000100\\nN -1.449100 -1.036100 0.000000\\nN -0.814800 -2.218300 0.000100\\nC -1.850000 -3.060900 -0.000200\\nN -3.087000 -2.482700 0.000200\\n\",\"xyz\");\n",
       "\tviewergrid_17465447455522041[0][5].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}, \"sphere\": {\"scale\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}});\n",
       "\tviewergrid_17465447455522041[0][0].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][1].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][2].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][3].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][4].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][5].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][5].addModel(\"49\\n\\nC -2.799100 -1.201900 -0.000100\\nN -1.449100 -1.036100 0.000000\\nN -0.814800 -2.218300 0.000100\\nC -1.850000 -3.060900 -0.000200\\nN -3.087000 -2.482700 0.000200\\nH -1.749902 -4.142825 -0.017826\\nC 0.627141 -2.355077 -0.026450\\nH 0.889720 -3.275759 0.481916\\nC 1.165053 -2.353167 -1.469546\\nH 2.244127 -2.450148 -1.422976\\nC 0.784439 -1.104223 -2.254291\\nC 1.361102 0.193258 -1.672533\\nO 0.905884 1.325329 -2.394067\\nC -0.338717 1.824163 -2.173792\\nC -1.102051 1.692701 -1.009376\\nC -2.338019 2.289780 -0.915996\\nC -2.841229 3.031131 -1.995585\\nC -2.073092 3.202203 -3.140373\\nC -0.830900 2.593240 -3.225718\\nH -0.222909 2.710805 -4.107958\\nH -2.437979 3.799814 -3.966326\\nC -4.119779 3.628366 -1.899142\\nC -5.198647 4.137827 -1.835868\\nC -6.496937 4.735146 -1.706287\\nC -6.610501 5.918965 -2.677011\\nC -5.574172 7.007582 -2.367330\\nC -5.748822 7.522051 -0.938332\\nC -5.589903 6.371551 0.027243\\nC -6.625757 5.305589 -0.272982\\nH -7.635399 5.711557 -0.173267\\nH -6.536569 4.459565 0.429912\\nH -5.672285 6.724654 1.063329\\nH -4.587306 5.935208 -0.067257\\nH -5.005718 8.294034 -0.733351\\nH -6.714706 7.992824 -0.822777\\nH -5.722057 7.840546 -3.091578\\nH -4.587528 6.589805 -2.505089\\nH -6.467308 5.551594 -3.699138\\nH -7.637864 6.369616 -2.614443\\nH -7.284837 3.959351 -1.948984\\nH -2.934168 2.205671 -0.012930\\nH -0.726271 1.131769 -0.159580\\nH 2.450660 0.208328 -1.795732\\nH 1.141487 0.292493 -0.600904\\nH 1.131384 -1.180782 -3.282395\\nH -0.301686 -1.027418 -2.281593\\nH 0.763443 -3.211558 -1.991412\\nH 1.037087 -1.515012 0.540437\\nH -3.417812 -0.328996 0.005538\\n\",\"xyz\");\n",
       "\tviewergrid_17465447455522041[0][5].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2}, \"sphere\": {\"scale\": 0.2}});\n",
       "\tviewergrid_17465447455522041[0][0].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][1].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][2].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][3].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][4].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][5].zoomTo();\n",
       "\tviewergrid_17465447455522041[0][0].zoom(0.9);\n",
       "\tviewergrid_17465447455522041[0][1].zoom(0.9);\n",
       "\tviewergrid_17465447455522041[0][2].zoom(0.9);\n",
       "\tviewergrid_17465447455522041[0][3].zoom(0.9);\n",
       "\tviewergrid_17465447455522041[0][4].zoom(0.9);\n",
       "\tviewergrid_17465447455522041[0][5].zoom(0.9);\n",
       "viewergrid_17465447455522041[0][5].render();\n",
       "viewergrid_17465447455522041[0][4].render();\n",
       "viewergrid_17465447455522041[0][3].render();\n",
       "viewergrid_17465447455522041[0][2].render();\n",
       "viewergrid_17465447455522041[0][1].render();\n",
       "viewergrid_17465447455522041[0][0].render();\n",
       "});\n",
       "</script>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "a, x = parse_xyz(\"124triazole.xyz\")\n",
    "x = x + torch.tensor([-2, -2, 0.0])\n",
    "out = torch.load(\"124triazole.pt\", weights_only=False)\n",
    "\n",
    "res = 700\n",
    "view = py3Dmol.view(width=res*6, height=res, viewergrid=(1, 6))\n",
    "view.rotate(180, {'x': 0, 'y': 1})\n",
    "view.translate(50, 0)\n",
    "for i in range(6):\n",
    "    M = out[0][i]\n",
    "    view = Molecule(a, x).show(view=view, viewer=(0, i), zoom=True, color=\"cyan\", opacity=0.6)\n",
    "    view = M.show(view=view, viewer=(0, i), zoom=True)\n",
    "view.zoom(0.9)\n",
    "view.show()\n",
    "make_html(view, \"124triazole.html\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 14%|█▍        | 25/178 [00:10<01:03,  2.40it/s]\n"
     ]
    }
   ],
   "source": [
    "a, x = parse_xyz(\"thiophene.xyz\")\n",
    "x = x + torch.tensor([2, 0.0, 0.0])\n",
    "\n",
    "out = model.generate(6, prefix=(a, x), **kwargs)\n",
    "torch.save(out, \"thiophene.pt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/3dmoljs_load.v0": "<div id=\"3dmolviewer_17465447401469114\"  style=\"position: relative; width: 4200px; height: 700px;\">\n        <p id=\"3dmolwarning_17465447401469114\" style=\"background-color:#ffcccc;color:black\">3Dmol.js failed to load for some reason.  Please check your browser console for error messages.<br></p>\n        </div>\n<script>\n\nvar loadScriptAsync = function(uri){\n  return new Promise((resolve, reject) => {\n    //this is to ignore the existence of requirejs amd\n    var savedexports, savedmodule;\n    if (typeof exports !== 'undefined') savedexports = exports;\n    else exports = {}\n    if (typeof module !== 'undefined') savedmodule = module;\n    else module = {}\n\n    var tag = document.createElement('script');\n    tag.src = uri;\n    tag.async = true;\n    tag.onload = () => {\n        exports = savedexports;\n        module = savedmodule;\n        resolve();\n    };\n  var firstScriptTag = document.getElementsByTagName('script')[0];\n  firstScriptTag.parentNode.insertBefore(tag, firstScriptTag);\n});\n};\n\nif(typeof $3Dmolpromise === 'undefined') {\n$3Dmolpromise = null;\n  $3Dmolpromise = loadScriptAsync('XXXX');\n}\n\nvar viewer_17465447401469114 = null;\nvar warn = document.getElementById(\"3dmolwarning_17465447401469114\");\nif(warn) {\n    warn.parentNode.removeChild(warn);\n}\n$3Dmolpromise.then(function() {\nvar viewergrid_17465447401469114 = null;\nviewergrid_17465447401469114 = $3Dmol.createViewerGrid(document.getElementById(\"3dmolviewer_17465447401469114\"),{rows: 1, cols: 6, control_all: true},{backgroundColor:\"white\"});\nviewer_17465447401469114 = viewergrid_17465447401469114[0][0];\nviewergrid_17465447401469114[0][0].zoomTo();viewergrid_17465447401469114[0][1].zoomTo();viewergrid_17465447401469114[0][2].zoomTo();viewergrid_17465447401469114[0][3].zoomTo();viewergrid_17465447401469114[0][4].zoomTo();viewergrid_17465447401469114[0][5].zoomTo();\tviewergrid_17465447401469114[0][0].rotate(180,{\"x\": 0, \"y\": 1});\n\tviewergrid_17465447401469114[0][1].rotate(180,{\"x\": 0, \"y\": 1});\n\tviewergrid_17465447401469114[0][2].rotate(180,{\"x\": 0, \"y\": 1});\n\tviewergrid_17465447401469114[0][3].rotate(180,{\"x\": 0, \"y\": 1});\n\tviewergrid_17465447401469114[0][4].rotate(180,{\"x\": 0, \"y\": 1});\n\tviewergrid_17465447401469114[0][5].rotate(180,{\"x\": 0, \"y\": 1});\n\tviewergrid_17465447401469114[0][0].translate(50,0);\n\tviewergrid_17465447401469114[0][1].translate(50,0);\n\tviewergrid_17465447401469114[0][2].translate(50,0);\n\tviewergrid_17465447401469114[0][3].translate(50,0);\n\tviewergrid_17465447401469114[0][4].translate(50,0);\n\tviewergrid_17465447401469114[0][5].translate(50,0);\n\tviewergrid_17465447401469114[0][0].addModel(\"5\\n\\nC 0.995000 -0.711600 0.000100\\nC 2.271300 -1.230000 -0.000100\\nS 3.464000 -0.001100 0.000000\\nC 2.273300 1.229500 0.000000\\nC 0.996300 0.713200 0.000000\\n\",\"xyz\");\n\tviewergrid_17465447401469114[0][0].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}, \"sphere\": {\"scale\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}});\n\tviewergrid_17465447401469114[0][0].zoomTo();\n\tviewergrid_17465447401469114[0][1].zoomTo();\n\tviewergrid_17465447401469114[0][2].zoomTo();\n\tviewergrid_17465447401469114[0][3].zoomTo();\n\tviewergrid_17465447401469114[0][4].zoomTo();\n\tviewergrid_17465447401469114[0][5].zoomTo();\n\tviewergrid_17465447401469114[0][0].addModel(\"19\\n\\nC 0.995000 -0.711600 0.000100\\nC 2.271300 -1.230000 -0.000100\\nS 3.464000 -0.001100 0.000000\\nC 2.273300 1.229500 0.000000\\nC 0.996300 0.713200 0.000000\\nH 0.098550 1.313695 0.016497\\nC 2.681136 2.609928 0.000588\\nC 1.876864 3.736614 -0.019378\\nS 2.870761 5.155596 -0.000665\\nC 4.291070 4.101259 0.024984\\nN 4.027826 2.858282 0.045127\\nN 5.542935 4.663077 0.000543\\nH 5.570867 5.599016 0.383249\\nN 6.557566 3.830894 0.477957\\nH 7.276996 3.760829 -0.218144\\nH 6.156294 2.902713 0.648460\\nH 0.817752 3.791303 -0.063422\\nH 2.582910 -2.251672 -0.004618\\nH 0.112876 -1.317718 -0.002540\\n\",\"xyz\");\n\tviewergrid_17465447401469114[0][0].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2}, \"sphere\": {\"scale\": 0.2}});\n\tviewergrid_17465447401469114[0][0].zoomTo();\n\tviewergrid_17465447401469114[0][1].zoomTo();\n\tviewergrid_17465447401469114[0][2].zoomTo();\n\tviewergrid_17465447401469114[0][3].zoomTo();\n\tviewergrid_17465447401469114[0][4].zoomTo();\n\tviewergrid_17465447401469114[0][5].zoomTo();\n\tviewergrid_17465447401469114[0][1].addModel(\"5\\n\\nC 0.995000 -0.711600 0.000100\\nC 2.271300 -1.230000 -0.000100\\nS 3.464000 -0.001100 0.000000\\nC 2.273300 1.229500 0.000000\\nC 0.996300 0.713200 0.000000\\n\",\"xyz\");\n\tviewergrid_17465447401469114[0][1].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}, \"sphere\": {\"scale\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}});\n\tviewergrid_17465447401469114[0][0].zoomTo();\n\tviewergrid_17465447401469114[0][1].zoomTo();\n\tviewergrid_17465447401469114[0][2].zoomTo();\n\tviewergrid_17465447401469114[0][3].zoomTo();\n\tviewergrid_17465447401469114[0][4].zoomTo();\n\tviewergrid_17465447401469114[0][5].zoomTo();\n\tviewergrid_17465447401469114[0][1].addModel(\"21\\n\\nC 0.995000 -0.711600 0.000100\\nC 2.271300 -1.230000 -0.000100\\nS 3.464000 -0.001100 0.000000\\nC 2.273300 1.229500 0.000000\\nC 0.996300 0.713200 0.000000\\nH 0.093226 1.309608 0.000224\\nC 2.664898 2.605153 0.080995\\nN 3.858368 2.996948 0.448860\\nC 3.822848 4.355618 0.421442\\nN 4.783940 5.217035 0.697768\\nC 4.477174 6.515020 0.582547\\nC 3.225673 6.978560 0.180515\\nC 2.214865 6.103556 -0.098924\\nC 2.533380 4.754500 0.035515\\nN 1.840583 3.598497 -0.170731\\nH 0.877132 3.507811 -0.478330\\nH 1.227837 6.463835 -0.408419\\nH 3.049259 8.047863 0.102674\\nH 5.285192 7.198822 0.802398\\nH 2.563669 -2.264737 -0.006867\\nH 0.098095 -1.322638 -0.015978\\n\",\"xyz\");\n\tviewergrid_17465447401469114[0][1].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2}, \"sphere\": {\"scale\": 0.2}});\n\tviewergrid_17465447401469114[0][0].zoomTo();\n\tviewergrid_17465447401469114[0][1].zoomTo();\n\tviewergrid_17465447401469114[0][2].zoomTo();\n\tviewergrid_17465447401469114[0][3].zoomTo();\n\tviewergrid_17465447401469114[0][4].zoomTo();\n\tviewergrid_17465447401469114[0][5].zoomTo();\n\tviewergrid_17465447401469114[0][2].addModel(\"5\\n\\nC 0.995000 -0.711600 0.000100\\nC 2.271300 -1.230000 -0.000100\\nS 3.464000 -0.001100 0.000000\\nC 2.273300 1.229500 0.000000\\nC 0.996300 0.713200 0.000000\\n\",\"xyz\");\n\tviewergrid_17465447401469114[0][2].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}, \"sphere\": {\"scale\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}});\n\tviewergrid_17465447401469114[0][0].zoomTo();\n\tviewergrid_17465447401469114[0][1].zoomTo();\n\tviewergrid_17465447401469114[0][2].zoomTo();\n\tviewergrid_17465447401469114[0][3].zoomTo();\n\tviewergrid_17465447401469114[0][4].zoomTo();\n\tviewergrid_17465447401469114[0][5].zoomTo();\n\tviewergrid_17465447401469114[0][2].addModel(\"30\\n\\nC 0.995000 -0.711600 0.000100\\nC 2.271300 -1.230000 -0.000100\\nS 3.464000 -0.001100 0.000000\\nC 2.273300 1.229500 0.000000\\nC 0.996300 0.713200 0.000000\\nH 0.112041 1.315631 0.010387\\nC 2.643937 2.602890 -0.003060\\nN 1.768501 3.588324 0.021943\\nO 2.523376 4.734138 0.007719\\nC 3.804075 4.324785 -0.037231\\nN 3.915408 3.050726 -0.040978\\nC 4.859065 5.362960 -0.073008\\nC 6.204477 4.739967 -0.390606\\nC 6.339362 4.438454 -1.873005\\nC 6.143147 5.734636 -2.696403\\nC 4.768951 6.317418 -2.432093\\nC 4.568897 6.614079 -0.941712\\nH 3.589789 7.013077 -0.735607\\nH 5.301727 7.380067 -0.609446\\nH 4.011414 5.591801 -2.767114\\nH 4.612622 7.236639 -2.992712\\nH 6.925672 6.469609 -2.439568\\nH 6.256203 5.520382 -3.767972\\nH 5.611833 3.699165 -2.140628\\nH 7.337646 4.022473 -2.089917\\nH 6.317230 3.830591 0.183009\\nH 7.010928 5.452560 -0.108115\\nH 4.887284 5.785901 0.933926\\nH 2.571913 -2.251283 0.001090\\nH 0.139405 -1.302526 0.008139\\n\",\"xyz\");\n\tviewergrid_17465447401469114[0][2].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2}, \"sphere\": {\"scale\": 0.2}});\n\tviewergrid_17465447401469114[0][0].zoomTo();\n\tviewergrid_17465447401469114[0][1].zoomTo();\n\tviewergrid_17465447401469114[0][2].zoomTo();\n\tviewergrid_17465447401469114[0][3].zoomTo();\n\tviewergrid_17465447401469114[0][4].zoomTo();\n\tviewergrid_17465447401469114[0][5].zoomTo();\n\tviewergrid_17465447401469114[0][3].addModel(\"5\\n\\nC 0.995000 -0.711600 0.000100\\nC 2.271300 -1.230000 -0.000100\\nS 3.464000 -0.001100 0.000000\\nC 2.273300 1.229500 0.000000\\nC 0.996300 0.713200 0.000000\\n\",\"xyz\");\n\tviewergrid_17465447401469114[0][3].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}, \"sphere\": {\"scale\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}});\n\tviewergrid_17465447401469114[0][0].zoomTo();\n\tviewergrid_17465447401469114[0][1].zoomTo();\n\tviewergrid_17465447401469114[0][2].zoomTo();\n\tviewergrid_17465447401469114[0][3].zoomTo();\n\tviewergrid_17465447401469114[0][4].zoomTo();\n\tviewergrid_17465447401469114[0][5].zoomTo();\n\tviewergrid_17465447401469114[0][3].addModel(\"26\\n\\nC 0.995000 -0.711600 0.000100\\nC 2.271300 -1.230000 -0.000100\\nS 3.464000 -0.001100 0.000000\\nC 2.273300 1.229500 0.000000\\nC 0.996300 0.713200 0.000000\\nH 0.109240 1.308432 0.012188\\nC 2.619257 2.607579 0.061326\\nN 1.710495 3.555638 0.107498\\nN 2.419310 4.691905 0.205889\\nC 3.760942 4.474216 0.251983\\nS 4.921950 5.587390 0.409335\\nN 3.878321 3.120508 0.147980\\nC 5.123831 2.420684 0.184291\\nC 5.790317 2.172463 -0.997980\\nC 7.011194 1.482671 -0.983321\\nC 7.525776 1.049216 0.232291\\nC 6.852587 1.291922 1.417494\\nC 5.673127 1.989905 1.416942\\nH 5.127406 2.209010 2.344530\\nH 7.251059 0.953624 2.349278\\nH 8.479901 0.497705 0.240044\\nH 7.540687 1.287891 -1.910249\\nH 5.391093 2.526594 -1.934984\\nH 1.962217 5.588758 0.256293\\nH 2.570235 -2.257449 -0.005152\\nH 0.117137 -1.322487 -0.014134\\n\",\"xyz\");\n\tviewergrid_17465447401469114[0][3].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2}, \"sphere\": {\"scale\": 0.2}});\n\tviewergrid_17465447401469114[0][0].zoomTo();\n\tviewergrid_17465447401469114[0][1].zoomTo();\n\tviewergrid_17465447401469114[0][2].zoomTo();\n\tviewergrid_17465447401469114[0][3].zoomTo();\n\tviewergrid_17465447401469114[0][4].zoomTo();\n\tviewergrid_17465447401469114[0][5].zoomTo();\n\tviewergrid_17465447401469114[0][4].addModel(\"5\\n\\nC 0.995000 -0.711600 0.000100\\nC 2.271300 -1.230000 -0.000100\\nS 3.464000 -0.001100 0.000000\\nC 2.273300 1.229500 0.000000\\nC 0.996300 0.713200 0.000000\\n\",\"xyz\");\n\tviewergrid_17465447401469114[0][4].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}, \"sphere\": {\"scale\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}});\n\tviewergrid_17465447401469114[0][0].zoomTo();\n\tviewergrid_17465447401469114[0][1].zoomTo();\n\tviewergrid_17465447401469114[0][2].zoomTo();\n\tviewergrid_17465447401469114[0][3].zoomTo();\n\tviewergrid_17465447401469114[0][4].zoomTo();\n\tviewergrid_17465447401469114[0][5].zoomTo();\n\tviewergrid_17465447401469114[0][4].addModel(\"30\\n\\nC 0.995000 -0.711600 0.000100\\nC 2.271300 -1.230000 -0.000100\\nS 3.464000 -0.001100 0.000000\\nC 2.273300 1.229500 0.000000\\nC 0.996300 0.713200 0.000000\\nH 0.101745 1.312273 0.002941\\nC 2.655400 2.611495 -0.013025\\nN 3.865327 3.099606 -0.019066\\nN 3.759152 4.437933 -0.027280\\nC 2.506858 4.727526 -0.025612\\nO 1.719796 3.616242 -0.019516\\nC 1.906330 6.075055 0.048302\\nC 1.542307 6.408858 1.495967\\nC 0.985138 7.840044 1.588285\\nC -0.248551 7.972364 0.693772\\nC 0.107327 7.623723 -0.772291\\nC 0.689919 6.213972 -0.842579\\nH -0.048630 5.483702 -0.515301\\nH 0.963374 5.973667 -1.877288\\nH -0.800301 7.701963 -1.389536\\nH 0.833059 8.337255 -1.151312\\nH -0.608449 9.002979 0.750032\\nH -1.034733 7.319883 1.064925\\nH 0.738525 8.048970 2.605671\\nH 1.744757 8.542107 1.231658\\nH 0.815109 5.697484 1.848104\\nH 2.426142 6.313428 2.115724\\nH 2.654938 6.780348 -0.284938\\nH 2.573863 -2.264374 -0.035414\\nH 0.133592 -1.302726 -0.023525\\n\",\"xyz\");\n\tviewergrid_17465447401469114[0][4].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2}, \"sphere\": {\"scale\": 0.2}});\n\tviewergrid_17465447401469114[0][0].zoomTo();\n\tviewergrid_17465447401469114[0][1].zoomTo();\n\tviewergrid_17465447401469114[0][2].zoomTo();\n\tviewergrid_17465447401469114[0][3].zoomTo();\n\tviewergrid_17465447401469114[0][4].zoomTo();\n\tviewergrid_17465447401469114[0][5].zoomTo();\n\tviewergrid_17465447401469114[0][5].addModel(\"5\\n\\nC 0.995000 -0.711600 0.000100\\nC 2.271300 -1.230000 -0.000100\\nS 3.464000 -0.001100 0.000000\\nC 2.273300 1.229500 0.000000\\nC 0.996300 0.713200 0.000000\\n\",\"xyz\");\n\tviewergrid_17465447401469114[0][5].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}, \"sphere\": {\"scale\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}});\n\tviewergrid_17465447401469114[0][0].zoomTo();\n\tviewergrid_17465447401469114[0][1].zoomTo();\n\tviewergrid_17465447401469114[0][2].zoomTo();\n\tviewergrid_17465447401469114[0][3].zoomTo();\n\tviewergrid_17465447401469114[0][4].zoomTo();\n\tviewergrid_17465447401469114[0][5].zoomTo();\n\tviewergrid_17465447401469114[0][5].addModel(\"28\\n\\nC 0.995000 -0.711600 0.000100\\nC 2.271300 -1.230000 -0.000100\\nS 3.464000 -0.001100 0.000000\\nC 2.273300 1.229500 0.000000\\nC 0.996300 0.713200 0.000000\\nH 0.098642 1.308385 -0.005078\\nC 2.660320 2.599043 0.000470\\nN 3.870812 3.067901 -0.014391\\nN 3.760794 4.414964 0.010018\\nC 2.502748 4.701557 0.023986\\nO 1.743971 3.588742 0.027166\\nC 1.891107 6.067698 0.019427\\nO 1.545990 6.511030 -1.278021\\nC 0.505332 5.940937 -1.958508\\nC -0.383002 4.975439 -1.446902\\nC -1.393612 4.459146 -2.222525\\nC -1.539146 4.886849 -3.548579\\nC -0.666609 5.863199 -4.078434\\nC 0.342010 6.387449 -3.285044\\nH 1.026895 7.136960 -3.658877\\nH -0.789946 6.197657 -5.081443\\nCl -2.783558 4.235011 -4.538346\\nH -2.083886 3.734545 -1.831699\\nH -0.290485 4.628881 -0.440035\\nH 1.042900 6.091223 0.701368\\nH 2.666871 6.772819 0.355683\\nH 2.571624 -2.241036 0.001196\\nH 0.137334 -1.331378 -0.006663\\n\",\"xyz\");\n\tviewergrid_17465447401469114[0][5].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2}, \"sphere\": {\"scale\": 0.2}});\n\tviewergrid_17465447401469114[0][0].zoomTo();\n\tviewergrid_17465447401469114[0][1].zoomTo();\n\tviewergrid_17465447401469114[0][2].zoomTo();\n\tviewergrid_17465447401469114[0][3].zoomTo();\n\tviewergrid_17465447401469114[0][4].zoomTo();\n\tviewergrid_17465447401469114[0][5].zoomTo();\n\tviewergrid_17465447401469114[0][0].zoom(0.9);\n\tviewergrid_17465447401469114[0][1].zoom(0.9);\n\tviewergrid_17465447401469114[0][2].zoom(0.9);\n\tviewergrid_17465447401469114[0][3].zoom(0.9);\n\tviewergrid_17465447401469114[0][4].zoom(0.9);\n\tviewergrid_17465447401469114[0][5].zoom(0.9);\nviewergrid_17465447401469114[0][5].render();\nviewergrid_17465447401469114[0][4].render();\nviewergrid_17465447401469114[0][3].render();\nviewergrid_17465447401469114[0][2].render();\nviewergrid_17465447401469114[0][1].render();\nviewergrid_17465447401469114[0][0].render();\n});\n</script>",
      "text/html": [
       "<div id=\"3dmolviewer_17465447401469114\"  style=\"position: relative; width: 4200px; height: 700px;\">\n",
       "        <p id=\"3dmolwarning_17465447401469114\" style=\"background-color:#ffcccc;color:black\">3Dmol.js failed to load for some reason.  Please check your browser console for error messages.<br></p>\n",
       "        </div>\n",
       "<script>\n",
       "\n",
       "var loadScriptAsync = function(uri){\n",
       "  return new Promise((resolve, reject) => {\n",
       "    //this is to ignore the existence of requirejs amd\n",
       "    var savedexports, savedmodule;\n",
       "    if (typeof exports !== 'undefined') savedexports = exports;\n",
       "    else exports = {}\n",
       "    if (typeof module !== 'undefined') savedmodule = module;\n",
       "    else module = {}\n",
       "\n",
       "    var tag = document.createElement('script');\n",
       "    tag.src = uri;\n",
       "    tag.async = true;\n",
       "    tag.onload = () => {\n",
       "        exports = savedexports;\n",
       "        module = savedmodule;\n",
       "        resolve();\n",
       "    };\n",
       "  var firstScriptTag = document.getElementsByTagName('script')[0];\n",
       "  firstScriptTag.parentNode.insertBefore(tag, firstScriptTag);\n",
       "});\n",
       "};\n",
       "\n",
       "if(typeof $3Dmolpromise === 'undefined') {\n",
       "$3Dmolpromise = null;\n",
       "  $3Dmolpromise = loadScriptAsync('XXXX');\n",
       "}\n",
       "\n",
       "var viewer_17465447401469114 = null;\n",
       "var warn = document.getElementById(\"3dmolwarning_17465447401469114\");\n",
       "if(warn) {\n",
       "    warn.parentNode.removeChild(warn);\n",
       "}\n",
       "$3Dmolpromise.then(function() {\n",
       "var viewergrid_17465447401469114 = null;\n",
       "viewergrid_17465447401469114 = $3Dmol.createViewerGrid(document.getElementById(\"3dmolviewer_17465447401469114\"),{rows: 1, cols: 6, control_all: true},{backgroundColor:\"white\"});\n",
       "viewer_17465447401469114 = viewergrid_17465447401469114[0][0];\n",
       "viewergrid_17465447401469114[0][0].zoomTo();viewergrid_17465447401469114[0][1].zoomTo();viewergrid_17465447401469114[0][2].zoomTo();viewergrid_17465447401469114[0][3].zoomTo();viewergrid_17465447401469114[0][4].zoomTo();viewergrid_17465447401469114[0][5].zoomTo();\tviewergrid_17465447401469114[0][0].rotate(180,{\"x\": 0, \"y\": 1});\n",
       "\tviewergrid_17465447401469114[0][1].rotate(180,{\"x\": 0, \"y\": 1});\n",
       "\tviewergrid_17465447401469114[0][2].rotate(180,{\"x\": 0, \"y\": 1});\n",
       "\tviewergrid_17465447401469114[0][3].rotate(180,{\"x\": 0, \"y\": 1});\n",
       "\tviewergrid_17465447401469114[0][4].rotate(180,{\"x\": 0, \"y\": 1});\n",
       "\tviewergrid_17465447401469114[0][5].rotate(180,{\"x\": 0, \"y\": 1});\n",
       "\tviewergrid_17465447401469114[0][0].translate(50,0);\n",
       "\tviewergrid_17465447401469114[0][1].translate(50,0);\n",
       "\tviewergrid_17465447401469114[0][2].translate(50,0);\n",
       "\tviewergrid_17465447401469114[0][3].translate(50,0);\n",
       "\tviewergrid_17465447401469114[0][4].translate(50,0);\n",
       "\tviewergrid_17465447401469114[0][5].translate(50,0);\n",
       "\tviewergrid_17465447401469114[0][0].addModel(\"5\\n\\nC 0.995000 -0.711600 0.000100\\nC 2.271300 -1.230000 -0.000100\\nS 3.464000 -0.001100 0.000000\\nC 2.273300 1.229500 0.000000\\nC 0.996300 0.713200 0.000000\\n\",\"xyz\");\n",
       "\tviewergrid_17465447401469114[0][0].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}, \"sphere\": {\"scale\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}});\n",
       "\tviewergrid_17465447401469114[0][0].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][1].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][2].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][3].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][4].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][5].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][0].addModel(\"19\\n\\nC 0.995000 -0.711600 0.000100\\nC 2.271300 -1.230000 -0.000100\\nS 3.464000 -0.001100 0.000000\\nC 2.273300 1.229500 0.000000\\nC 0.996300 0.713200 0.000000\\nH 0.098550 1.313695 0.016497\\nC 2.681136 2.609928 0.000588\\nC 1.876864 3.736614 -0.019378\\nS 2.870761 5.155596 -0.000665\\nC 4.291070 4.101259 0.024984\\nN 4.027826 2.858282 0.045127\\nN 5.542935 4.663077 0.000543\\nH 5.570867 5.599016 0.383249\\nN 6.557566 3.830894 0.477957\\nH 7.276996 3.760829 -0.218144\\nH 6.156294 2.902713 0.648460\\nH 0.817752 3.791303 -0.063422\\nH 2.582910 -2.251672 -0.004618\\nH 0.112876 -1.317718 -0.002540\\n\",\"xyz\");\n",
       "\tviewergrid_17465447401469114[0][0].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2}, \"sphere\": {\"scale\": 0.2}});\n",
       "\tviewergrid_17465447401469114[0][0].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][1].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][2].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][3].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][4].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][5].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][1].addModel(\"5\\n\\nC 0.995000 -0.711600 0.000100\\nC 2.271300 -1.230000 -0.000100\\nS 3.464000 -0.001100 0.000000\\nC 2.273300 1.229500 0.000000\\nC 0.996300 0.713200 0.000000\\n\",\"xyz\");\n",
       "\tviewergrid_17465447401469114[0][1].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}, \"sphere\": {\"scale\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}});\n",
       "\tviewergrid_17465447401469114[0][0].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][1].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][2].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][3].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][4].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][5].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][1].addModel(\"21\\n\\nC 0.995000 -0.711600 0.000100\\nC 2.271300 -1.230000 -0.000100\\nS 3.464000 -0.001100 0.000000\\nC 2.273300 1.229500 0.000000\\nC 0.996300 0.713200 0.000000\\nH 0.093226 1.309608 0.000224\\nC 2.664898 2.605153 0.080995\\nN 3.858368 2.996948 0.448860\\nC 3.822848 4.355618 0.421442\\nN 4.783940 5.217035 0.697768\\nC 4.477174 6.515020 0.582547\\nC 3.225673 6.978560 0.180515\\nC 2.214865 6.103556 -0.098924\\nC 2.533380 4.754500 0.035515\\nN 1.840583 3.598497 -0.170731\\nH 0.877132 3.507811 -0.478330\\nH 1.227837 6.463835 -0.408419\\nH 3.049259 8.047863 0.102674\\nH 5.285192 7.198822 0.802398\\nH 2.563669 -2.264737 -0.006867\\nH 0.098095 -1.322638 -0.015978\\n\",\"xyz\");\n",
       "\tviewergrid_17465447401469114[0][1].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2}, \"sphere\": {\"scale\": 0.2}});\n",
       "\tviewergrid_17465447401469114[0][0].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][1].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][2].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][3].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][4].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][5].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][2].addModel(\"5\\n\\nC 0.995000 -0.711600 0.000100\\nC 2.271300 -1.230000 -0.000100\\nS 3.464000 -0.001100 0.000000\\nC 2.273300 1.229500 0.000000\\nC 0.996300 0.713200 0.000000\\n\",\"xyz\");\n",
       "\tviewergrid_17465447401469114[0][2].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}, \"sphere\": {\"scale\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}});\n",
       "\tviewergrid_17465447401469114[0][0].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][1].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][2].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][3].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][4].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][5].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][2].addModel(\"30\\n\\nC 0.995000 -0.711600 0.000100\\nC 2.271300 -1.230000 -0.000100\\nS 3.464000 -0.001100 0.000000\\nC 2.273300 1.229500 0.000000\\nC 0.996300 0.713200 0.000000\\nH 0.112041 1.315631 0.010387\\nC 2.643937 2.602890 -0.003060\\nN 1.768501 3.588324 0.021943\\nO 2.523376 4.734138 0.007719\\nC 3.804075 4.324785 -0.037231\\nN 3.915408 3.050726 -0.040978\\nC 4.859065 5.362960 -0.073008\\nC 6.204477 4.739967 -0.390606\\nC 6.339362 4.438454 -1.873005\\nC 6.143147 5.734636 -2.696403\\nC 4.768951 6.317418 -2.432093\\nC 4.568897 6.614079 -0.941712\\nH 3.589789 7.013077 -0.735607\\nH 5.301727 7.380067 -0.609446\\nH 4.011414 5.591801 -2.767114\\nH 4.612622 7.236639 -2.992712\\nH 6.925672 6.469609 -2.439568\\nH 6.256203 5.520382 -3.767972\\nH 5.611833 3.699165 -2.140628\\nH 7.337646 4.022473 -2.089917\\nH 6.317230 3.830591 0.183009\\nH 7.010928 5.452560 -0.108115\\nH 4.887284 5.785901 0.933926\\nH 2.571913 -2.251283 0.001090\\nH 0.139405 -1.302526 0.008139\\n\",\"xyz\");\n",
       "\tviewergrid_17465447401469114[0][2].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2}, \"sphere\": {\"scale\": 0.2}});\n",
       "\tviewergrid_17465447401469114[0][0].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][1].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][2].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][3].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][4].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][5].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][3].addModel(\"5\\n\\nC 0.995000 -0.711600 0.000100\\nC 2.271300 -1.230000 -0.000100\\nS 3.464000 -0.001100 0.000000\\nC 2.273300 1.229500 0.000000\\nC 0.996300 0.713200 0.000000\\n\",\"xyz\");\n",
       "\tviewergrid_17465447401469114[0][3].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}, \"sphere\": {\"scale\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}});\n",
       "\tviewergrid_17465447401469114[0][0].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][1].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][2].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][3].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][4].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][5].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][3].addModel(\"26\\n\\nC 0.995000 -0.711600 0.000100\\nC 2.271300 -1.230000 -0.000100\\nS 3.464000 -0.001100 0.000000\\nC 2.273300 1.229500 0.000000\\nC 0.996300 0.713200 0.000000\\nH 0.109240 1.308432 0.012188\\nC 2.619257 2.607579 0.061326\\nN 1.710495 3.555638 0.107498\\nN 2.419310 4.691905 0.205889\\nC 3.760942 4.474216 0.251983\\nS 4.921950 5.587390 0.409335\\nN 3.878321 3.120508 0.147980\\nC 5.123831 2.420684 0.184291\\nC 5.790317 2.172463 -0.997980\\nC 7.011194 1.482671 -0.983321\\nC 7.525776 1.049216 0.232291\\nC 6.852587 1.291922 1.417494\\nC 5.673127 1.989905 1.416942\\nH 5.127406 2.209010 2.344530\\nH 7.251059 0.953624 2.349278\\nH 8.479901 0.497705 0.240044\\nH 7.540687 1.287891 -1.910249\\nH 5.391093 2.526594 -1.934984\\nH 1.962217 5.588758 0.256293\\nH 2.570235 -2.257449 -0.005152\\nH 0.117137 -1.322487 -0.014134\\n\",\"xyz\");\n",
       "\tviewergrid_17465447401469114[0][3].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2}, \"sphere\": {\"scale\": 0.2}});\n",
       "\tviewergrid_17465447401469114[0][0].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][1].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][2].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][3].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][4].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][5].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][4].addModel(\"5\\n\\nC 0.995000 -0.711600 0.000100\\nC 2.271300 -1.230000 -0.000100\\nS 3.464000 -0.001100 0.000000\\nC 2.273300 1.229500 0.000000\\nC 0.996300 0.713200 0.000000\\n\",\"xyz\");\n",
       "\tviewergrid_17465447401469114[0][4].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}, \"sphere\": {\"scale\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}});\n",
       "\tviewergrid_17465447401469114[0][0].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][1].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][2].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][3].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][4].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][5].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][4].addModel(\"30\\n\\nC 0.995000 -0.711600 0.000100\\nC 2.271300 -1.230000 -0.000100\\nS 3.464000 -0.001100 0.000000\\nC 2.273300 1.229500 0.000000\\nC 0.996300 0.713200 0.000000\\nH 0.101745 1.312273 0.002941\\nC 2.655400 2.611495 -0.013025\\nN 3.865327 3.099606 -0.019066\\nN 3.759152 4.437933 -0.027280\\nC 2.506858 4.727526 -0.025612\\nO 1.719796 3.616242 -0.019516\\nC 1.906330 6.075055 0.048302\\nC 1.542307 6.408858 1.495967\\nC 0.985138 7.840044 1.588285\\nC -0.248551 7.972364 0.693772\\nC 0.107327 7.623723 -0.772291\\nC 0.689919 6.213972 -0.842579\\nH -0.048630 5.483702 -0.515301\\nH 0.963374 5.973667 -1.877288\\nH -0.800301 7.701963 -1.389536\\nH 0.833059 8.337255 -1.151312\\nH -0.608449 9.002979 0.750032\\nH -1.034733 7.319883 1.064925\\nH 0.738525 8.048970 2.605671\\nH 1.744757 8.542107 1.231658\\nH 0.815109 5.697484 1.848104\\nH 2.426142 6.313428 2.115724\\nH 2.654938 6.780348 -0.284938\\nH 2.573863 -2.264374 -0.035414\\nH 0.133592 -1.302726 -0.023525\\n\",\"xyz\");\n",
       "\tviewergrid_17465447401469114[0][4].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2}, \"sphere\": {\"scale\": 0.2}});\n",
       "\tviewergrid_17465447401469114[0][0].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][1].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][2].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][3].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][4].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][5].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][5].addModel(\"5\\n\\nC 0.995000 -0.711600 0.000100\\nC 2.271300 -1.230000 -0.000100\\nS 3.464000 -0.001100 0.000000\\nC 2.273300 1.229500 0.000000\\nC 0.996300 0.713200 0.000000\\n\",\"xyz\");\n",
       "\tviewergrid_17465447401469114[0][5].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}, \"sphere\": {\"scale\": 0.2, \"color\": \"cyan\", \"opacity\": 0.6}});\n",
       "\tviewergrid_17465447401469114[0][0].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][1].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][2].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][3].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][4].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][5].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][5].addModel(\"28\\n\\nC 0.995000 -0.711600 0.000100\\nC 2.271300 -1.230000 -0.000100\\nS 3.464000 -0.001100 0.000000\\nC 2.273300 1.229500 0.000000\\nC 0.996300 0.713200 0.000000\\nH 0.098642 1.308385 -0.005078\\nC 2.660320 2.599043 0.000470\\nN 3.870812 3.067901 -0.014391\\nN 3.760794 4.414964 0.010018\\nC 2.502748 4.701557 0.023986\\nO 1.743971 3.588742 0.027166\\nC 1.891107 6.067698 0.019427\\nO 1.545990 6.511030 -1.278021\\nC 0.505332 5.940937 -1.958508\\nC -0.383002 4.975439 -1.446902\\nC -1.393612 4.459146 -2.222525\\nC -1.539146 4.886849 -3.548579\\nC -0.666609 5.863199 -4.078434\\nC 0.342010 6.387449 -3.285044\\nH 1.026895 7.136960 -3.658877\\nH -0.789946 6.197657 -5.081443\\nCl -2.783558 4.235011 -4.538346\\nH -2.083886 3.734545 -1.831699\\nH -0.290485 4.628881 -0.440035\\nH 1.042900 6.091223 0.701368\\nH 2.666871 6.772819 0.355683\\nH 2.571624 -2.241036 0.001196\\nH 0.137334 -1.331378 -0.006663\\n\",\"xyz\");\n",
       "\tviewergrid_17465447401469114[0][5].setStyle({\"model\": -1},{\"stick\": {\"radius\": 0.2}, \"sphere\": {\"scale\": 0.2}});\n",
       "\tviewergrid_17465447401469114[0][0].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][1].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][2].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][3].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][4].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][5].zoomTo();\n",
       "\tviewergrid_17465447401469114[0][0].zoom(0.9);\n",
       "\tviewergrid_17465447401469114[0][1].zoom(0.9);\n",
       "\tviewergrid_17465447401469114[0][2].zoom(0.9);\n",
       "\tviewergrid_17465447401469114[0][3].zoom(0.9);\n",
       "\tviewergrid_17465447401469114[0][4].zoom(0.9);\n",
       "\tviewergrid_17465447401469114[0][5].zoom(0.9);\n",
       "viewergrid_17465447401469114[0][5].render();\n",
       "viewergrid_17465447401469114[0][4].render();\n",
       "viewergrid_17465447401469114[0][3].render();\n",
       "viewergrid_17465447401469114[0][2].render();\n",
       "viewergrid_17465447401469114[0][1].render();\n",
       "viewergrid_17465447401469114[0][0].render();\n",
       "});\n",
       "</script>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "a, x = parse_xyz(\"thiophene.xyz\")\n",
    "x = x + torch.tensor([2, 0.0, 0.0])\n",
    "\n",
    "out = torch.load(\"thiophene.pt\", weights_only=False)\n",
    "\n",
    "res = 700\n",
    "view = py3Dmol.view(width=res*6, height=res, viewergrid=(1, 6))\n",
    "view.rotate(180, {'x': 0, 'y': 1})\n",
    "view.translate(50, 0)\n",
    "for i in range(6):\n",
    "    M = out[0][i]\n",
    "    view = Molecule(a, x).show(view=view, viewer=(0, i), zoom=True, color=\"cyan\", opacity=0.6)\n",
    "    view = M.show(view=view, viewer=(0, i), zoom=True)\n",
    "view.zoom(0.9)\n",
    "view.show()\n",
    "make_html(view, \"thiophene.html\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "dar2",
   "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.10.16"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
