{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "ae491722",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "UserWarning: Environment variable TORCH_FORCE_NO_WEIGHTS_ONLY_LOAD detected, since the`weights_only` argument was not explicitly passed to `torch.load`, forcing weights_only=False.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cuequivariance or cuequivariance_torch is not available. Cuequivariance acceleration will be disabled.\n"
     ]
    }
   ],
   "source": [
    "import gzip\n",
    "import json\n",
    "import os\n",
    "import pickle\n",
    "from typing import Literal\n",
    "\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import seaborn as sns\n",
    "from colorama import Fore, Style\n",
    "from matplotlib import pyplot as plt\n",
    "from pymatgen.ext.matproj import MPRester\n",
    "from tabulate import tabulate\n",
    "\n",
    "from xgemval.convert import structure2crystal\n",
    "from xgemval.crystal import Crystal\n",
    "from xgemval.distance import d_amd, d_comp, d_magpie, d_smat, d_wyckoff"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "bd137ede",
   "metadata": {},
   "source": [
    "### Table 1: Distances between example pairs of crystals based on composition and structure metrics."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "11de33e9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "wz-ZnO(mp-2133) vs wz-ZnO(mp-2133, 2x2x2 supercell) - same composition, same structure\n",
      "d_comp: 0.0\n",
      "d_wyckoff: 0.0\n",
      "d_smat: 0.0\n",
      "d_magpie: 0.000e+00\n",
      "d_amd: 1.776e-15\n",
      "\n",
      "wz-ZnO(mp-2133) vs rs-ZnO(mp-2229) - same composition, different structure\n",
      "d_comp: 0.0\n",
      "d_wyckoff: 1.0\n",
      "d_smat: 1.0\n",
      "d_magpie: 0.000e+00\n",
      "d_amd: 1.042e+00\n",
      "\n",
      "wz-ZnO(mp-2133) vs wz-GaN(mp-804) - different composition, same structure\n",
      "d_comp: 1.0\n",
      "d_wyckoff: 0.0\n",
      "d_smat: 1.0\n",
      "d_magpie: 6.298e+02\n",
      "d_amd: 9.684e-02\n",
      "\n",
      "wz-ZnO(mp-2133) vs Bi2Te3(mp-34202) - different composition, different structure\n",
      "d_comp: 1.0\n",
      "d_wyckoff: 1.0\n",
      "d_smat: 1.0\n",
      "d_magpie: 1.070e+03\n",
      "d_amd: 3.240e+00\n",
      "\n"
     ]
    }
   ],
   "source": [
    "MP_API_KEY=\"\" # set your API key\n",
    "# MP_API_KEY = os.getenv(\"MP_API_KEY\")\n",
    "mpr = MPRester(MP_API_KEY)\n",
    "pairs = [\n",
    "    [\"mp-2133\"],  # same composition, same structure\n",
    "    [\"mp-2133\", \"mp-2229\"],  # same composition, different structure\n",
    "    [\"mp-2133\", \"mp-804\"],  # different composition, same structure\n",
    "    [\"mp-2133\", \"mp-34202\"],  # different composition, different structure\n",
    "]\n",
    "texts = [\n",
    "    \"wz-ZnO(mp-2133) vs wz-ZnO(mp-2133, 2x2x2 supercell) - same composition, same structure\",\n",
    "    \"wz-ZnO(mp-2133) vs rs-ZnO(mp-2229) - same composition, different structure\",\n",
    "    \"wz-ZnO(mp-2133) vs wz-GaN(mp-804) - different composition, same structure\",\n",
    "    \"wz-ZnO(mp-2133) vs Bi2Te3(mp-34202) - different composition, different structure\",\n",
    "]\n",
    "for pair, text in zip(pairs, texts, strict=False):\n",
    "    print(text)\n",
    "    docs = mpr.materials.summary.search(material_ids=pair)\n",
    "\n",
    "    xtal_1 = structure2crystal(docs[0][\"structure\"])\n",
    "    if len(docs) == 1:\n",
    "        # get 2x2x2 supercell\n",
    "        frac_coords_1 = xtal_1.frac_coords\n",
    "        atom_types_1 = xtal_1.atom_types\n",
    "        lengths_1 = xtal_1.lengths\n",
    "        angles_1 = xtal_1.angles\n",
    "        frac_coords_2 = []\n",
    "        atom_types_2 = []\n",
    "        for frac_coord, atom_type in zip(frac_coords_1, atom_types_1, strict=False):\n",
    "            for i in range(2):\n",
    "                for j in range(2):\n",
    "                    for k in range(2):\n",
    "                        frac_coords_2.append(\n",
    "                            [\n",
    "                                (frac_coord[0] + i) / 2,\n",
    "                                (frac_coord[1] + j) / 2,\n",
    "                                (frac_coord[2] + k) / 2,\n",
    "                            ]\n",
    "                        )\n",
    "                        atom_types_2.append(atom_type)\n",
    "        lengths_2 = [x * 2 for x in lengths_1]\n",
    "        angles_2 = angles_1\n",
    "        xtal_2 = Crystal(\n",
    "            frac_coords=frac_coords_2,\n",
    "            atom_types=atom_types_2,\n",
    "            lengths=lengths_2,\n",
    "            angles=angles_2,\n",
    "        )\n",
    "    else:\n",
    "        xtal_2 = structure2crystal(docs[1][\"structure\"])\n",
    "\n",
    "    print(f\"d_comp: {d_comp(xtal_1, xtal_2)}\")\n",
    "    print(f\"d_wyckoff: {d_wyckoff(xtal_1, xtal_2)}\")\n",
    "    print(f\"d_smat: {d_smat(xtal_1, xtal_2)}\")\n",
    "    print(f\"d_magpie: {d_magpie(xtal_1, xtal_2):.3e}\")\n",
    "    print(f\"d_amd: {d_amd(xtal_1, xtal_2):.3e}\")\n",
    "    print()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "fe876324",
   "metadata": {},
   "source": [
    "### Table 2: Uniqueness (U) and Novelty (N) results."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "6e7a7288",
   "metadata": {},
   "outputs": [],
   "source": [
    "MODELS = [\n",
    "\t\"cdvae\",\n",
    "\t\"diffcsp\",\n",
    "\t\"diffcsppp\",\n",
    "\t\"mattergen\",\n",
    "\t\"chemeleon\",\n",
    "\t\"adit\",\n",
    "]\n",
    "MODEL_NAMES = {\n",
    "\t\"cdvae\": \"CDVAE\",\n",
    "\t\"diffcsp\": \"DiffCSP\",\n",
    "\t\"diffcsppp\": \"DiffCSP++\",\n",
    "\t\"mattergen\": \"MatterGen\",\n",
    "\t\"chemeleon\": \"Chemeleon-DNG\",\n",
    "\t\"adit\": \"ADiT\",\n",
    "}\n",
    "DISTANCES = [\"smat\", \"comp\", \"wyckoff\", \"magpie\", \"amd\"]\n",
    "DISTANCE_NAMES = {\n",
    "\t\"smat\": r\"$d_\\mathrm{smat}$\",\n",
    "\t\"comp\": r\"$d_\\mathrm{comp}$\",\n",
    "\t\"wyckoff\": r\"$d_\\mathrm{wyckoff}$\",\n",
    "\t\"magpie\": r\"$d_\\mathrm{magpie}$\",\n",
    "\t\"amd\": r\"$d_\\mathrm{amd}$\",\n",
    "}\n",
    "METRIC_NAMES = {\n",
    "\t\"uniqueness\": \"Uniqueness\",\n",
    "\t\"uniqueness_ehull\": \"Uniqueness (Ehull)\",\n",
    "\t\"novelty\": \"Novelty\",\n",
    "\t\"novelty_ehull\": \"Novelty (Ehull)\",\n",
    "}\n",
    "TIME_NAMES = {\n",
    "\t\"time_embed_train\": \"Embed (train)\",\n",
    "\t\"time_embed_gen\": \"Embed (gen)\",\n",
    "\t\"time_uniqueness_matrix\": \"Uni Mat\",\n",
    "\t\"time_uniqueness\": \"Uni\",\n",
    "\t\"time_novelty_matrix\": \"Nov Mat\",\n",
    "\t\"time_novelty\": \"Nov\",\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "d0964427",
   "metadata": {},
   "outputs": [],
   "source": [
    "def print_table_metric(\n",
    "\tmetric: Literal[\n",
    "\t\t\"uniqueness\",\n",
    "\t\t\"uniqueness_ehull\",\n",
    "\t\t\"novelty\",\n",
    "\t\t\"novelty_ehull\",\n",
    "\t],\n",
    ") -> None:\n",
    "\t\"\"\"Print a table showing the uniqueness/novelty results of the experiment.\n",
    "\n",
    "\tArgs:\n",
    "\t\tmetric (Literal): The metric to display in the table.\n",
    "\t\"\"\"\n",
    "\tprint(f\"{METRIC_NAMES[metric]}\")\n",
    "\trslt_dir = os.path.join(os.getcwd(), \"rslt\")\n",
    "\theaders = [\"model\"] + DISTANCES\n",
    "\trows = []\n",
    "\tfor model in MODELS:\n",
    "\t\twith open(os.path.join(rslt_dir, model, \"metrics.json\")) as f:\n",
    "\t\t\tdata = json.load(f)\n",
    "\t\trows.append([data[d][metric] for d in DISTANCES])\n",
    "\tvalues_highlighted = np.max(np.array(rows), axis=0).tolist()\n",
    "\trows_highlighted = [\n",
    "\t\t[\n",
    "\t\t\tFore.RED + Style.BRIGHT + str(cell) + Style.RESET_ALL\n",
    "\t\t\tif cell == values_highlighted[i]\n",
    "\t\t\telse str(cell)\n",
    "\t\t\tfor i, cell in enumerate(row)\n",
    "\t\t]\n",
    "\t\tfor row in rows\n",
    "\t]\n",
    "\tprint(\n",
    "\t\ttabulate(\n",
    "\t\t\t[[MODEL_NAMES[MODELS[i]]] + row for i, row in enumerate(rows_highlighted)],\n",
    "\t\t\theaders=headers,\n",
    "\t\t\ttablefmt=\"grid\",\n",
    "\t\t\tfloatfmt=\".4f\",\n",
    "\t\t)\n",
    "\t)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "d969c1bf",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Uniqueness\n",
      "+---------------+--------+--------+-----------+-----------+--------+\n",
      "| model         |   smat |   comp |   wyckoff |    magpie |    amd |\n",
      "+===============+========+========+===========+===========+========+\n",
      "| CDVAE         | \u001b[31m\u001b[1m0.9945\u001b[0m | \u001b[31m\u001b[1m0.9717\u001b[0m |    0.0045 | 1795.0511 | 1.2070 |\n",
      "+---------------+--------+--------+-----------+-----------+--------+\n",
      "| DiffCSP       | 0.9771 | 0.9461 |    0.0324 | 1981.5799 | 1.5921 |\n",
      "+---------------+--------+--------+-----------+-----------+--------+\n",
      "| DiffCSP++     | 0.9806 | 0.9522 |    \u001b[31m\u001b[1m0.1910\u001b[0m | 2070.4490 | 1.3768 |\n",
      "+---------------+--------+--------+-----------+-----------+--------+\n",
      "| MatterGen     | 0.9838 | 0.9523 |    0.0470 | \u001b[31m\u001b[1m2088.9824\u001b[0m | 1.4168 |\n",
      "+---------------+--------+--------+-----------+-----------+--------+\n",
      "| Chemeleon-DNG | 0.9791 | 0.9373 |    0.0637 | 2083.8927 | \u001b[31m\u001b[1m2.6800\u001b[0m |\n",
      "+---------------+--------+--------+-----------+-----------+--------+\n",
      "| ADiT          | 0.8841 | 0.7743 |    0.0038 | 2073.5381 | 1.2726 |\n",
      "+---------------+--------+--------+-----------+-----------+--------+\n",
      "\n",
      "\n",
      "Uniqueness (Ehull)\n",
      "+---------------+--------+--------+-----------+----------+--------+\n",
      "| model         |   smat |   comp |   wyckoff |   magpie |    amd |\n",
      "+===============+========+========+===========+==========+========+\n",
      "| CDVAE         | 0.0346 | 0.0341 |    0.0021 |   1.9947 | 0.0016 |\n",
      "+---------------+--------+--------+-----------+----------+--------+\n",
      "| DiffCSP       | 0.2885 | 0.2775 |    0.0209 | 177.3017 | 0.1378 |\n",
      "+---------------+--------+--------+-----------+----------+--------+\n",
      "| DiffCSP++     | 0.2723 | 0.2646 |    0.0423 | 159.7310 | 0.1175 |\n",
      "+---------------+--------+--------+-----------+----------+--------+\n",
      "| MatterGen     | 0.3517 | 0.3372 |    0.0371 | 253.0440 | 0.2014 |\n",
      "+---------------+--------+--------+-----------+----------+--------+\n",
      "| Chemeleon-DNG | \u001b[31m\u001b[1m0.3747\u001b[0m | \u001b[31m\u001b[1m0.3599\u001b[0m |    \u001b[31m\u001b[1m0.0439\u001b[0m | \u001b[31m\u001b[1m297.5159\u001b[0m | \u001b[31m\u001b[1m0.2272\u001b[0m |\n",
      "+---------------+--------+--------+-----------+----------+--------+\n",
      "| ADiT          | 0.3164 | 0.3089 |    0.0033 | 269.5051 | 0.1832 |\n",
      "+---------------+--------+--------+-----------+----------+--------+\n",
      "\n",
      "\n",
      "Novelty\n",
      "+---------------+--------+--------+-----------+----------+--------+\n",
      "| model         |   smat |   comp |   wyckoff |   magpie |    amd |\n",
      "+===============+========+========+===========+==========+========+\n",
      "| CDVAE         | \u001b[31m\u001b[1m0.9892\u001b[0m | \u001b[31m\u001b[1m0.9221\u001b[0m |    0.0352 | \u001b[31m\u001b[1m106.3339\u001b[0m | 0.1974 |\n",
      "+---------------+--------+--------+-----------+----------+--------+\n",
      "| DiffCSP       | 0.9050 | 0.8207 |    0.0812 |  84.7846 | 0.2175 |\n",
      "+---------------+--------+--------+-----------+----------+--------+\n",
      "| DiffCSP++     | 0.8925 | 0.8121 |    0.0098 |  88.2989 | 0.1291 |\n",
      "+---------------+--------+--------+-----------+----------+--------+\n",
      "| MatterGen     | 0.9158 | 0.8156 |    0.0967 |  77.2610 | 0.1415 |\n",
      "+---------------+--------+--------+-----------+----------+--------+\n",
      "| Chemeleon-DNG | 0.8630 | 0.7497 |    \u001b[31m\u001b[1m0.1134\u001b[0m |  67.8230 | \u001b[31m\u001b[1m0.6976\u001b[0m |\n",
      "+---------------+--------+--------+-----------+----------+--------+\n",
      "| ADiT          | 0.4582 | 0.2352 |    0.0425 |  15.4543 | 0.1358 |\n",
      "+---------------+--------+--------+-----------+----------+--------+\n",
      "\n",
      "\n",
      "Novelty (Ehull)\n",
      "+---------------+--------+--------+-----------+----------+--------+\n",
      "| model         |   smat |   comp |   wyckoff |   magpie |    amd |\n",
      "+===============+========+========+===========+==========+========+\n",
      "| CDVAE         | 0.0319 | 0.0295 |    0.0012 |   3.1471 | 0.0075 |\n",
      "+---------------+--------+--------+-----------+----------+--------+\n",
      "| DiffCSP       | 0.2190 | 0.1816 |    0.0368 |  16.0266 | 0.0217 |\n",
      "+---------------+--------+--------+-----------+----------+--------+\n",
      "| DiffCSP++     | 0.1890 | 0.1619 |    0.0013 |  13.2714 | 0.0168 |\n",
      "+---------------+--------+--------+-----------+----------+--------+\n",
      "| MatterGen     | \u001b[31m\u001b[1m0.2845\u001b[0m | \u001b[31m\u001b[1m0.2294\u001b[0m |    \u001b[31m\u001b[1m0.0554\u001b[0m |  \u001b[31m\u001b[1m18.7534\u001b[0m | 0.0390 |\n",
      "+---------------+--------+--------+-----------+----------+--------+\n",
      "| Chemeleon-DNG | 0.2621 | 0.2158 |    0.0512 |  16.8273 | 0.0250 |\n",
      "+---------------+--------+--------+-----------+----------+--------+\n",
      "| ADiT          | 0.0722 | 0.0604 |    0.0323 |   3.7983 | \u001b[31m\u001b[1m0.0431\u001b[0m |\n",
      "+---------------+--------+--------+-----------+----------+--------+\n",
      "\n",
      "\n"
     ]
    }
   ],
   "source": [
    "for metric in METRIC_NAMES:\n",
    "    print_table_metric(metric)\n",
    "    print(\"\\n\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "12b86bfd",
   "metadata": {},
   "source": [
    "### Table 4: Ratio of samples that are classified as thermodynamically metastable, i.e., $E_\\mathrm{hull} \\le$ 0.1[eV/atom]."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "69bd5364",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "+---------+-----------+-------------+-------------+-----------------+--------+\n",
      "|   CDVAE |   DiffCSP |   DiffCSP++ |   MatterGen |   Chemeleon-DNG |   ADiT |\n",
      "+=========+===========+=============+=============+=================+========+\n",
      "|  0.0348 |    0.3087 |      0.2871 |      0.3646 |          0.3909 | 0.3708 |\n",
      "+---------+-----------+-------------+-------------+-----------------+--------+\n"
     ]
    }
   ],
   "source": [
    "headers = [MODEL_NAMES[model] for model in MODELS]\n",
    "rslts = []\n",
    "for model in MODELS:\n",
    "    with gzip.open(\n",
    "        os.path.join(\n",
    "            os.getcwd(), \"rslt\", model, \"screen_ehull.pkl.gz\"\n",
    "        ),\n",
    "        \"rb\",\n",
    "    ) as f:\n",
    "        valid_indices = pickle.load(f)\n",
    "    rslts.append(np.sum(valid_indices) / len(valid_indices))\n",
    "print(\n",
    "    tabulate(\n",
    "        [rslts],\n",
    "        headers=headers,\n",
    "        tablefmt=\"grid\",\n",
    "        floatfmt=\".4f\",\n",
    "    )\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5ae66a46",
   "metadata": {},
   "source": [
    "### Table 5: Computation time [s] required to calculate the uniqueness and novelty metrics on all the 10k samples generated from CDVAE trained on the MP20 dataset. A single CPU (AMD EPYC 7742) with 32 GB of RAM was used."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "3634029d",
   "metadata": {},
   "outputs": [],
   "source": [
    "def print_table_time(\n",
    "\tmodel: Literal[\n",
    "\t\t\"cdvae\",\n",
    "\t\t\"diffcsp\",\n",
    "\t\t\"diffcsppp\",\n",
    "\t\t\"mattergen\",\n",
    "\t\t\"chemeleon\",\n",
    "\t\t\"adit\",\n",
    "\t],\n",
    "\tdataset: Literal[\"mp20\"],\n",
    ") -> None:\n",
    "\t\"\"\"Print a table showing the computation time for each model.\n",
    "\n",
    "\tArgs:\n",
    "\t\tmodel (Literal): The model to display the time for.\n",
    "\t\tdataset (Literal): The dataset used for the experiment.\n",
    "\t\"\"\"\n",
    "\tprint(f\"Computation time [s] for {MODEL_NAMES[model]}/{dataset}\")\n",
    "\twith open(\n",
    "\t\tos.path.join(os.getcwd(), \"rslt\", model, \"metrics.json\")\n",
    "\t) as f:\n",
    "\t\tmodel_rslt = json.load(f)\n",
    "\twith open(\n",
    "\t\tos.path.join(os.getcwd(), \"data\", dataset, \"metrics.json\")\n",
    "\t) as f:\n",
    "\t\tdataset_rslt = json.load(f)\n",
    "\n",
    "\theaders = [] + DISTANCES\n",
    "\trows = []\n",
    "\tfor key in TIME_NAMES:\n",
    "\t\tif key == \"time_embed_train\":\n",
    "\t\t\trows.append([dataset_rslt[d][key] for d in DISTANCES])\n",
    "\t\telse:\n",
    "\t\t\trows.append([model_rslt[d][key] for d in DISTANCES])\n",
    "\trows.append(\n",
    "\t\t[\n",
    "\t\t\trows[0][i] + rows[1][i] + rows[2][i] + rows[3][i]\n",
    "\t\t\tfor i in range(len(DISTANCES))\n",
    "\t\t]\n",
    "\t)  # uniqueness\n",
    "\trows.append(\n",
    "\t\t[\n",
    "\t\t\trows[0][i] + rows[1][i] + rows[4][i] + rows[5][i]\n",
    "\t\t\tfor i in range(len(DISTANCES))\n",
    "\t\t]\n",
    "\t)  # novelty\n",
    "\tprint(\n",
    "\t\ttabulate(\n",
    "\t\t\t[\n",
    "\t\t\t\t[TIME_NAMES[key]] + row\n",
    "\t\t\t\tfor key, row in zip(TIME_NAMES, rows[:6], strict=False)\n",
    "\t\t\t]\n",
    "\t\t\t+ [[\"Uni (total)\"] + rows[6]]\n",
    "\t\t\t+ [[\"Nov (total)\"] + rows[7]],\n",
    "\t\t\theaders=headers,\n",
    "\t\t\ttablefmt=\"grid\",\n",
    "\t\t\tfloatfmt=\".3e\",\n",
    "\t\t)\n",
    "\t)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "24d5f156",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Computation time [s] for CDVAE/mp20\n",
      "+---------------+-----------+-----------+-----------+-----------+-----------+\n",
      "|               |      smat |      comp |   wyckoff |    magpie |       amd |\n",
      "+===============+===========+===========+===========+===========+===========+\n",
      "| Embed (train) | 3.418e+00 | 2.563e-01 | 3.275e+02 | 1.388e+03 | 3.506e+02 |\n",
      "+---------------+-----------+-----------+-----------+-----------+-----------+\n",
      "| Embed (gen)   | 1.046e+00 | 7.057e-02 | 1.198e+01 | 5.679e+02 | 2.106e+01 |\n",
      "+---------------+-----------+-----------+-----------+-----------+-----------+\n",
      "| Uni Mat       | 1.622e+04 | 7.241e+00 | 1.329e+01 | 2.589e+01 | 2.332e+00 |\n",
      "+---------------+-----------+-----------+-----------+-----------+-----------+\n",
      "| Uni           | 1.547e-01 | 1.648e-01 | 1.567e-01 | 4.427e-02 | 4.366e-02 |\n",
      "+---------------+-----------+-----------+-----------+-----------+-----------+\n",
      "| Nov Mat       | 4.646e+04 | 1.964e+01 | 2.931e+01 | 8.250e+01 | 3.175e+01 |\n",
      "+---------------+-----------+-----------+-----------+-----------+-----------+\n",
      "| Nov           | 6.744e-01 | 6.417e-01 | 6.270e-01 | 1.608e-01 | 1.604e-01 |\n",
      "+---------------+-----------+-----------+-----------+-----------+-----------+\n",
      "| Uni (total)   | 1.622e+04 | 7.733e+00 | 3.529e+02 | 1.982e+03 | 3.740e+02 |\n",
      "+---------------+-----------+-----------+-----------+-----------+-----------+\n",
      "| Nov (total)   | 4.647e+04 | 2.061e+01 | 3.694e+02 | 2.038e+03 | 4.036e+02 |\n",
      "+---------------+-----------+-----------+-----------+-----------+-----------+\n"
     ]
    }
   ],
   "source": [
    "print_table_time(\"cdvae\", \"mp20\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "baabc1e9",
   "metadata": {},
   "source": [
    "### Figure 2: 2D plots showing the uniqueness and novelty of each model, which were computed after screening for thermodynamic stability. Different plots correspond to different distance functions. Pareto-optimal models are highlighted with a black circle."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "ec6b1d66",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA38AAAJbCAYAAABU/S0bAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjMsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvZiW1igAAAAlwSFlzAAAPYQAAD2EBqD+naQAA0xFJREFUeJzs3XlcVXX+x/HXZRFw4aoJigIi4ooLkJqpqWOLlIqmWVaWVO41TfUrzVEnbZykbZqWUbFMK9Oa0Ir2xjENy0xTW9QUVBYTxSVBQfbz+4O8eQPhApflct/Px+M+5t5zvt9zP8f0M/dzzvd8vybDMAxERERERESkQXOp6wBERERERESk5qn4ExERERERcQIq/kRERERERJyAij8REREREREnoOJPRERERETECaj4ExERERERcQIq/kRERERERJyAij8REREREREnoOJPRERERETECaj4ExERERERcQIq/kRERERERJyAij+pUwEBAZhMJtLS0uo6FBGRUpSjRKQuKQeJvZkMwzDqOghxTkePHqVdu3a0bt2aY8eO1XU4IiJWlKNEpC4pB0lN0J0/qTPbtm0DoE+fPnUciYhIacpRIlKXlIOkJqj4kzqjpCYi9ZlylIjUJeUgqQkq/qRGHTp0iKlTpxIQEICnpyehoaG8/PLLwO9JrW/fvnUZoog4MeUoEalLykFS29zqOgBpuN5//31uu+02cnJy6NmzJwMGDCApKYmpU6dy7NgxduzYAeiKlojUDeUoEalLykFSFzThi9SIb775hqFDh+Lu7s7bb7/NDTfcYNn37LPP8sgjj2AYBgEBAaSmptZhpCLijJSjRKQuKQdJXdGwT7G7oqIioqOjycvL47XXXrNKaAAPPfQQ/v7+QP26mvXee+/x0ksv1XUYIlLDHDVHiUjD4Gg5KDo6mq5du9rteM888wyBgYG4uroydOjQS26TmqHiT+zu7bffZv/+/QwePJixY8eW2m8ymejcuTNQv8axq/gTcQ6OmqNEpGFw5hz0008/8cgjj3DbbbeRkJDAkiVLytwmNUfP/IndrVu3DoBJkyZdsk1WVhZQP65oiYhzUY4SkbrkzDno559/BmDq1KkEBwcDEBcXV2qb1Bzd+RO7++677wC44oorytyfk5PDDz/8AFgntX379jFq1ChatWqFl5cXwcHB/OUvf7HsvzDsYNOmTYSH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9lnf/fzzz0b//v2NTp06GZdffrnxww8/GIZhGPfcc4/x/vvvG4ZRMgNSu3btjFatWhnu7u5Gu3btjEcffbQuw64WW8550aJFhpubm9G7d2/La9GiRXUZdrXYcs6xsbFGaGio0atXL6N79+7Gn//8Z+P8+fN1GbaIFWfMVxdzxtx1MeUxqU9s+ftoGIaxfPlyIzg42AgODjbuvvtuy4yS9SVXVfc86kvOqe551IfcUd1zuNjhw4frbMIXk2EYRu2WmyIiIiIiIlLbNOxTRERERETECaj4ExERERERcQIq/kRERERERJyAij8REREREREnoOJPRERERETECaj4ExERERERcQIq/qTKTCYTZ86csdoWFBTE7t27K+w7efJkvvjii5oJTETkIspVIlLfKU9JbXGr6wDEOb3yyit1HYKISIWUq0SkvlOeksrQnT+pMUFBQfztb3/jyiuvpEOHDixatMiyb+jQobz33nsApKenM3z4cLp3784111zDhAkTWLBgAQALFizggQcesPR76aWXiI6Otnx+5pln6NevHxEREURGRpKSkmLpd8sttzBq1Ci6d+/OsGHDOH36dIX9PvjgA3r16kVYWBg9evTg/fffB2DRokV069aNsLAwwsLCLO1FxPEpV4lIfac8JfaiO39So86cOcPWrVs5efIkHTt25K677qJdu3ZWbe6//3769evHZ599xi+//EJYWBhdu3at8Nhr1qxh//79bN26FVdXV9544w1mzpzJRx99BMC2bdv47rvvuOyyy5gwYQKxsbHMmTOn3H7z5s0jNjaWK6+8kuLiYrKysvj111955plnSE9Px8vLi5ycHFxcdN1EpCFRrhKR+k55SuxBxZ/Ynclksry/7bbbAGjVqhXBwcEcPny4VKL63//+xzPPPANAu3btiIqKsul73nvvPbZv387ll18OQFFRkdX+yMhILrvsMgCuvPJKfvzxxwr7XX311fzlL3/hpptu4rrrriMsLIyioiI6derExIkTue666xgxYgT+/v42/3mISP2kXCUi9Z3ylNibSm2pMh8fH06dOmW17eTJk/j6+lo+e3p6Wt67urpSWFhY4XEvTnRubm5WiSQ3N9fy3jAM5syZw+7du9m9ezc//vijJRmV993l9fvnP//JypUrady4MZMmTeKpp57C1dWVb775hgceeICMjAz69+9PQkJC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P1DxJyJ2KCkpicaNG+PkVNAFmkwmfHx8SExMLFT8JSYm0qxZM8u2r68viYmJJXqNuLg4QkJCcHR05NFHHyU8PPym7RYuXMj8+fPL8G5ERMQaderUwd/f/4Z19ErDxcVFozSqAUdHR5ycnIq8AlxdqPgTESlnISEhnD59Gg8PD06fPk2/fv3w9PTkoYceuqHt3LlzefLJJy3bqampeHt73850RUTsVsFwTq2VJ/ajel/XFBG5CW9vb86ePWsZpmMYBomJifj4+BRq5+Pjw6lTpyzbCQkJN7S5GXd3dzw8PADw8vJi5MiRbN++/aZtnZ2dcXd3L/QQERERsYUqWfxlZWUxY8YM/P39adeuHWPGjKnolESkCmnYsCEhISGsWLECgKioKLy8vAoN+YSCewHXrVtHcnIyhmEQERHBiBEjij3+2bNnLbOGpaWlsX79ejp06FD+b0RERESkFKrksM85c+ZgMpn46aefMJlMJCcnV3RKIlLFREZGMm7cOBYsWIC7uzvLly8HYOLEiQwYMIABAwbQokUL5s+fT/fu3QHo2bMnU6ZMASA9PZ2AgACysrJISUnBy8uLhx9+mIULFxIVFcWSJUtwcnIiNzeXYcOG8eijj1bYexURERGBKrjUw9WrV2ncuDGnT58udnjUzWbR8/b21hTqIlJpaakHERERsZUqN+wzLi6OO+64gwULFtCxY0fuuecetmzZctO2CxcuxMPDw/LQJAoiIiIiImKvqlzxl5uby6lTpwgKCmLfvn289dZbDB8+nHPnzt3Qdu7cuaSkpFgeSUlJFZCxiIiIiIhIxaty9/xdW3xx9OjRAHTo0IHmzZtz5MgR7rzzzkJtnZ2dcXZ2rog0RUREREREKpUqd+XP09OTe++9l02bNgEQHx9PfHw8gYGBFZyZiIiIiIhI5VXlrvwBREREMGHCBGbPno2DgwORkZE0bdq0otMSERERERGptKpk8deiRQu2bt1a0WmIiIiIiIhUGVVu2KeIiIiIiIiUnoo/ERERERERO6DiT0RERERExA6o+BMREREREbEDKv5ERERERETsgIo/ERERERERO6DiT0RERERExA6o+BMREREREbEDKv5ERERERETsgIo/ERERERERO6DiT0RERERExA6o+BMREREREbEDKv5ERERERETsgIo/EbFLMTExdOvWjYCAADp16sSxY8du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",
      "text/plain": [
       "<Figure size 900x600 with 6 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "rslt_dir = os.path.join(os.getcwd(), \"rslt\")\n",
    "uniqueness_scores = []\n",
    "novelty_scores = []\n",
    "models = []\n",
    "distances = []\n",
    "for model in MODELS:\n",
    "    with open(os.path.join(rslt_dir, model, \"metrics.json\")) as f:\n",
    "        data = json.load(f)\n",
    "    for distance in DISTANCES:\n",
    "        uniqueness_scores.append(data[distance][\"uniqueness_ehull\"])\n",
    "        novelty_scores.append(data[distance][\"novelty_ehull\"])\n",
    "        models.append(MODEL_NAMES[model])\n",
    "        distances.append(DISTANCE_NAMES[distance])\n",
    "df = pd.DataFrame(\n",
    "    {\n",
    "        \"Model\": models,\n",
    "        \"Distance\": distances,\n",
    "        \"Uniqueness\": uniqueness_scores,\n",
    "        \"Novelty\": novelty_scores,\n",
    "    }\n",
    ")\n",
    "\n",
    "g = sns.FacetGrid(\n",
    "    df, col=\"Distance\", col_wrap=3, hue=\"Model\", sharex=False, sharey=False\n",
    ")\n",
    "g.map(sns.scatterplot, \"Uniqueness\", \"Novelty\", s=150)\n",
    "g.set_titles(col_template=\"{col_name}\", size=16)\n",
    "g.set_axis_labels(\"Uniqueness\", \"Novelty\")\n",
    "\n",
    "for ax in g.axes:\n",
    "    ax.set_xlabel(\"Uniqueness\")\n",
    "    ax.set_ylabel(\"Novelty\")\n",
    "\n",
    "# highlight the Pareto front\n",
    "for idx, distance in enumerate(DISTANCES):\n",
    "    sub_df = df[(df[\"Distance\"] == DISTANCE_NAMES[distance])]\n",
    "    # Find Pareto front\n",
    "    p_uni = []\n",
    "    p_nov = []\n",
    "    for _, row_1 in sub_df.iterrows():\n",
    "        is_pareto = True\n",
    "        for _, row_2 in sub_df.iterrows():\n",
    "            if row_1[\"Model\"] == row_2[\"Model\"]:\n",
    "                continue\n",
    "            if (\n",
    "                row_1[\"Uniqueness\"] <= row_2[\"Uniqueness\"]\n",
    "                and row_1[\"Novelty\"] <= row_2[\"Novelty\"]\n",
    "            ):\n",
    "                is_pareto = False\n",
    "                break\n",
    "        if is_pareto:\n",
    "            p_uni.append(row_1[\"Uniqueness\"])\n",
    "            p_nov.append(row_1[\"Novelty\"])\n",
    "    g.axes[idx].scatter(\n",
    "        p_uni, p_nov, facecolors=\"none\", edgecolors=\"black\", linewidth=2, s=150\n",
    "    )\n",
    "\n",
    "# legend\n",
    "handles = g._legend_data.values()\n",
    "labels = g._legend_data.keys()\n",
    "ax_legend = g.figure.add_subplot(2, 3, 6)\n",
    "ax_legend.legend(\n",
    "    handles,\n",
    "    labels,\n",
    "    loc=\"center\",\n",
    "    title=\"Model\",\n",
    ")\n",
    "ax_legend.axis(\"off\")\n",
    "\n",
    "g.figure.subplots_adjust(wspace=0.3, hspace=0.4)\n",
    "os.makedirs(os.path.join(os.getcwd(), \"vis\"), exist_ok=True)\n",
    "g.savefig(os.path.join(os.getcwd(), \"vis\", \"pareto_plot_neurips2025.pdf\"))\n",
    "plt.show()\n",
    "plt.close(g.figure)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "xgemval",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.12.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
