{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "8510fc3e",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import scienceplots  # noqa\n",
    "import seaborn as sns\n",
    "\n",
    "plt.style.use(['science', 'grid'])\n",
    "plt.rcParams.update({'font.size': 16})\n",
    "\n",
    "# Set seaborn colorblind palette\n",
    "sns.set_theme(style='whitegrid')\n",
    "colors = sns.color_palette('deep')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "7f30a507",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Processing NNmGGA_scan_qm5 with loss config 0 ($E$), checkpoints (18, 20, 22)\n",
      "Processing NNmGGA_scan_qm5 with loss config 1 ($E + \\rho$), checkpoints (17, 19, 21)\n",
      "Processing NNmGGA_scan_qm5 with loss config 2 ($E + \\rho + \\nabla$), checkpoints (24, 26, 28)\n",
      "Processing NNmGGA_scan_qm5 with loss config 3 ($E + \\rho + \\nabla + H$), checkpoints (23, 25, 27)\n",
      "Processing XCdiff_scan_qm5 with loss config 0 ($E$), checkpoints (390, 394, 401)\n",
      "Processing XCdiff_scan_qm5 with loss config 1 ($E + \\rho$), checkpoints (389, 391, 402)\n",
      "Processing XCdiff_scan_qm5 with loss config 2 ($E + \\rho + \\nabla$), checkpoints (395, 399, 403)\n",
      "Processing XCdiff_scan_qm5 with loss config 3 ($E + \\rho + \\nabla + H$), checkpoints (396, 398, 400)\n",
      "Processing Skala_mGGA_scan_qm5 with loss config 0 ($E$), checkpoints (13, 34, 36)\n",
      "Processing Skala_mGGA_scan_qm5 with loss config 1 ($E + \\rho$), checkpoints (14, 35, 37)\n",
      "Processing Skala_mGGA_scan_qm5 with loss config 2 ($E + \\rho + \\nabla$), checkpoints (38, 40, 42)\n",
      "Processing Skala_mGGA_scan_qm5 with loss config 3 ($E + \\rho + \\nabla + H$), checkpoints (39, 41, 43)\n",
      "=== All Available Metrics ===\n",
      "\n",
      "Available metrics: ['idx', 'cycles_to_convergence', 'relative_cycle_count', 'total_energy_mae_mEh', 'xc_energy_mae_mEh', 'mean_field_mae_mEh', 'coulomb_energy_mae_mEh', 'dipole_difference_au', 'homo_lumo_gap_mae_mEh', 'density_L1', 'density_L2', 'overlap_based_mae_surrogate', 'overlap_based_mse_surrogate', 'ref_total_energy_on_model_dm_mEh', 'ref_xc_energy_on_model_dm_mEh']\n",
      "\n",
      "\n",
      "coulomb_energy_mae_mEh:\n",
      "Model           E_tot           + E_rho         + ∇             + H            \n",
      "------------------------------------------------------------------------------------------\n",
      "NNmGGA          138.45±10.90    468.61±122.70   1.14±0.39       1.20±0.29      \n",
      "XCdiff          135.32±71.70    561.10±142.21   1.02±0.06       0.6818±0.1032  \n",
      "Skala           197.81±59.57    204.81±45.50    4.01±1.49       3.08±0.52      \n",
      "\n",
      "cycles_to_convergence:\n",
      "Model           E_tot           + E_rho         + ∇             + H            \n",
      "------------------------------------------------------------------------------------------\n",
      "NNmGGA          9.72±0.10       9.85±0.06       9.32±0.00       9.33±0.01      \n",
      "XCdiff          9.58±0.16       10.17±0.41      9.33±0.00       9.33±0.00      \n",
      "Skala           9.53±0.09       9.54±0.06       9.36±0.06       9.31±0.01      \n",
      "\n",
      "density_L1:\n",
      "Model           E_tot           + E_rho         + ∇             + H            \n",
      "------------------------------------------------------------------------------------------\n",
      "NNmGGA          0.7657±0.1174   0.5423±0.1395   5.70e-03±3.43e-04 3.72e-03±4.85e-04\n",
      "XCdiff          0.5859±0.1076   0.5943±0.1010   3.62e-03±8.03e-04 2.14e-03±1.11e-04\n",
      "Skala           0.4994±0.0443   0.3411±0.0280   0.0150±0.0025   0.0123±0.0002  \n",
      "\n",
      "density_L2:\n",
      "Model           E_tot           + E_rho         + ∇             + H            \n",
      "------------------------------------------------------------------------------------------\n",
      "NNmGGA          0.0108±0.0026   7.17e-03±3.31e-03 1.81e-07±3.78e-08 7.68e-08±2.39e-08\n",
      "XCdiff          0.0104±0.0041   7.92e-03±3.74e-03 7.31e-08±3.13e-08 2.49e-08±2.17e-09\n",
      "Skala           6.09e-03±4.68e-04 2.89e-03±5.04e-04 1.11e-06±5.67e-07 5.32e-07±8.55e-08\n",
      "\n",
      "dipole_difference_au:\n",
      "Model           E_tot           + E_rho         + ∇             + H            \n",
      "------------------------------------------------------------------------------------------\n",
      "NNmGGA          0.0332±0.0025   0.0327±0.0070   9.03e-04±7.92e-05 6.31e-04±1.13e-04\n",
      "XCdiff          0.0231±0.0029   0.0210±0.0030   7.05e-04±1.60e-04 3.83e-04±4.41e-05\n",
      "Skala           0.0258±0.0015   0.0283±0.0004   3.43e-03±7.10e-04 2.82e-03±2.10e-04\n",
      "\n",
      "homo_lumo_gap_mae_mEh:\n",
      "Model           E_tot           + E_rho         + ∇             + H            \n",
      "------------------------------------------------------------------------------------------\n",
      "NNmGGA          21.36±1.91      14.84±4.67      0.1631±0.0160   0.1127±0.0351  \n",
      "XCdiff          16.69±5.65      14.85±1.74      0.2790±0.0719   0.1959±0.0365  \n",
      "Skala           11.92±1.87      12.27±1.58      0.8929±0.2288   0.3855±0.0436  \n",
      "\n",
      "idx:\n",
      "Model           E_tot           + E_rho         + ∇             + H            \n",
      "------------------------------------------------------------------------------------------\n",
      "NNmGGA          74160.42±0.00   74160.42±0.00   74160.42±0.00   74160.42±0.00  \n",
      "XCdiff          74160.42±0.00   74160.42±0.00   74160.42±0.00   74160.42±0.00  \n",
      "Skala           74160.42±0.00   74160.42±0.00   74160.42±0.00   74160.42±0.00  \n",
      "\n",
      "mean_field_mae_mEh:\n",
      "Model           E_tot           + E_rho         + ∇             + H            \n",
      "------------------------------------------------------------------------------------------\n",
      "NNmGGA          58.48±6.96      1.64±0.31       0.1353±0.0449   0.1377±0.0275  \n",
      "XCdiff          64.95±16.90     1.54±0.55       0.0693±0.0235   0.0455±0.0084  \n",
      "Skala           33.71±4.49      1.10±0.17       0.3995±0.1184   0.3547±0.0807  \n",
      "\n",
      "overlap_based_mae_surrogate:\n",
      "Model           E_tot           + E_rho         + ∇             + H            \n",
      "------------------------------------------------------------------------------------------\n",
      "NNmGGA          88.35±7.03      69.55±8.07      2.26±0.28       1.69±0.18      \n",
      "XCdiff          59.72±11.47     67.63±5.95      0.9814±0.1440   0.6449±0.0373  \n",
      "Skala           69.79±26.07     66.27±4.89      8.52±0.77       8.58±0.58      \n",
      "\n",
      "overlap_based_mse_surrogate:\n",
      "Model           E_tot           + E_rho         + ∇             + H            \n",
      "------------------------------------------------------------------------------------------\n",
      "NNmGGA          0.0348±0.0082   0.0209±0.0078   7.04e-06±9.49e-07 3.47e-06±5.52e-07\n",
      "XCdiff          0.0198±0.0058   0.0166±0.0054   2.10e-06±8.97e-07 7.39e-07±9.35e-08\n",
      "Skala           0.0165±0.0035   0.0116±0.0012   7.80e-05±1.77e-05 6.51e-05±9.78e-06\n",
      "\n",
      "ref_total_energy_on_model_dm_mEh:\n",
      "Model           E_tot           + E_rho         + ∇             + H            \n",
      "------------------------------------------------------------------------------------------\n",
      "NNmGGA          18.31±4.58      11.19±4.82      1.88e-03±2.63e-04 9.87e-04±2.11e-04\n",
      "XCdiff          11.45±3.25      11.28±3.83      6.94e-04±3.05e-04 2.49e-04±2.82e-05\n",
      "Skala           9.93±2.18       6.51±0.39       0.0186±0.0054   0.0146±0.0016  \n",
      "\n",
      "ref_xc_energy_on_model_dm_mEh:\n",
      "Model           E_tot           + E_rho         + ∇             + H            \n",
      "------------------------------------------------------------------------------------------\n",
      "NNmGGA          76.79±10.65     11.65±5.34      0.1352±0.0447   0.1373±0.0275  \n",
      "XCdiff          76.41±18.15     12.57±4.46      0.0694±0.0238   0.0454±0.0083  \n",
      "Skala           43.63±6.40      6.24±0.23       0.3996±0.1205   0.3462±0.0802  \n",
      "\n",
      "relative_cycle_count:\n",
      "Model           E_tot           + E_rho         + ∇             + H            \n",
      "------------------------------------------------------------------------------------------\n",
      "NNmGGA          1.04±0.01       1.05±0.01       0.9949±0.0001   0.9967±0.0006  \n",
      "XCdiff          1.02±0.02       1.09±0.05       0.9964±0.0005   0.9959±0.0003  \n",
      "Skala           1.02±0.01       1.02±0.01       0.9992±0.0058   0.9944±0.0015  \n",
      "\n",
      "total_energy_mae_mEh:\n",
      "Model           E_tot           + E_rho         + ∇             + H            \n",
      "------------------------------------------------------------------------------------------\n",
      "NNmGGA          2.09±0.21       2.44±0.72       0.3783±0.1407   0.9832±0.4233  \n",
      "XCdiff          1.16±0.19       1.40±0.47       0.2164±0.0107   0.3543±0.0464  \n",
      "Skala           1.90±0.32       1.28±0.10       1.40±0.59       1.84±0.61      \n",
      "\n",
      "xc_energy_mae_mEh:\n",
      "Model           E_tot           + E_rho         + ∇             + H            \n",
      "------------------------------------------------------------------------------------------\n",
      "NNmGGA          59.59±6.64      3.08±1.34       0.3441±0.1325   0.9168±0.3858  \n",
      "XCdiff          65.59±16.79     2.57±0.51       0.2089±0.0043   0.3310±0.0325  \n",
      "Skala           35.03±4.50      1.46±0.12       1.41±0.62       1.84±0.62      \n"
     ]
    }
   ],
   "source": [
    "# Example: Automatically aggregate metrics from checkpoints\n",
    "from aggregate_metrics import aggregate_model_loss_combinations\n",
    "\n",
    "# Define the model batches with their checkpoint indices\n",
    "# Same structure as in enhancement_factors.ipynb\n",
    "model_batches = [\n",
    "    [  # NNmGGA\n",
    "        ('NNmGGA_scan_qm5', None, r'$E$', (18, 20, 22)),\n",
    "        ('NNmGGA_scan_qm5', None, r'$E + \\rho$', (17, 19, 21)),\n",
    "        ('NNmGGA_scan_qm5', None, r'$E + \\rho + \\nabla$', (24, 26, 28)),\n",
    "        ('NNmGGA_scan_qm5', None, r'$E + \\rho + \\nabla + H$', (23, 25, 27)),\n",
    "    ],\n",
    "    [  # XCdiff\n",
    "        ('XCdiff_scan_qm5', None, r'$E$', (390, 394, 401)),\n",
    "        ('XCdiff_scan_qm5', None, r'$E + \\rho$', (389, 391, 402)),\n",
    "        ('XCdiff_scan_qm5', None, r'$E + \\rho + \\nabla$', (395, 399, 403)),\n",
    "        ('XCdiff_scan_qm5', None, r'$E + \\rho + \\nabla + H$', (396, 398, 400)),\n",
    "    ],\n",
    "    [  # Skala-mGGA\n",
    "        ('Skala_mGGA_scan_qm5', None, r'$E$', (13, 34, 36)),\n",
    "        ('Skala_mGGA_scan_qm5', None, r'$E + \\rho$', (14, 35, 37)),\n",
    "        ('Skala_mGGA_scan_qm5', None, r'$E + \\rho + \\nabla$', (38, 40, 42)),\n",
    "        ('Skala_mGGA_scan_qm5', None, r'$E + \\rho + \\nabla + H$', (39, 41, 43)),\n",
    "    ],\n",
    "]\n",
    "\n",
    "# Aggregate all metrics (use CSV for better precision, especially for small values)\n",
    "all_means, all_stds = aggregate_model_loss_combinations(\n",
    "    checkpoint_root='../evaluations/1000',\n",
    "    model_batches=model_batches,\n",
    "    use_csv=True,  # Use results.csv for better precision\n",
    ")\n",
    "\n",
    "# Display ALL available metrics\n",
    "print('=== All Available Metrics ===\\n')\n",
    "print(f'Available metrics: {list(all_means.keys())}\\n')\n",
    "\n",
    "# Print all metrics in a formatted way\n",
    "for metric_name in sorted(all_means.keys()):\n",
    "    print(f'\\n{metric_name}:')\n",
    "    print(f'{\"Model\":<15} {\"E_tot\":<15} {\"+ E_rho\":<15} {\"+ ∇\":<15} {\"+ H\":<15}')\n",
    "    print('-' * 90)\n",
    "    for model in ['NNmGGA', 'XCdiff', 'Skala']:\n",
    "        if model in all_means[metric_name]:\n",
    "            values = all_means[metric_name][model]\n",
    "            stds = all_stds[metric_name][model]\n",
    "\n",
    "            # Format with appropriate precision based on magnitude\n",
    "            formatted_vals = []\n",
    "            for v, s in zip(values, stds):\n",
    "                if abs(v) < 0.01:\n",
    "                    formatted_vals.append(f'{v:.2e}±{s:.2e}')\n",
    "                elif abs(v) < 1:\n",
    "                    formatted_vals.append(f'{v:.4f}±{s:.4f}')\n",
    "                else:\n",
    "                    formatted_vals.append(f'{v:.2f}±{s:.2f}')\n",
    "\n",
    "            print(\n",
    "                f'{model:<15} {formatted_vals[0]:<15} {formatted_vals[1]:<15} {formatted_vals[2]:<15} {formatted_vals[3]:<15}'\n",
    "            )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "6b1246fd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Data formatted for plotting!\n",
      "\n",
      "Available plot keys: ['E_tot', 'E_rho', 'E_xc', 'Delta_eps_HL', 'mu_rho', 'E_C', 'density_L1', 'density_L2']\n",
      "Models: ['NNmGGA', 'XC-diff', 'Skala-mGGA']\n",
      "Loss configurations: ['$E_\\\\mathrm{tot}$', '$+ E_\\\\rho$', '$+ \\\\nabla$ (ours)', '$+ H$ (ours)']\n",
      "\n",
      "Row 1 metrics: ['E_tot', 'E_rho', 'E_xc', 'Delta_eps_HL']\n",
      "Row 2 metrics: ['mu_rho', 'E_C', 'density_L1', 'density_L2']\n",
      "\n",
      "Example - E_tot data:\n",
      "  NNmGGA: [2.0926275557645035, 2.4449263812293034, 0.37832456784838087, 0.9832031310573939]\n",
      "  XC-diff: [1.1552714719748565, 1.4027033439660574, 0.21642118609467312, 0.3543490769811797]\n",
      "  Skala-mGGA: [1.8972540422350903, 1.281556166127795, 1.3952427330869266, 1.8391363438908002]\n"
     ]
    }
   ],
   "source": [
    "# Format data for plotting (map to the names expected by plotting code)\n",
    "models = ['NNmGGA', 'XC-diff', 'Skala-mGGA']\n",
    "losses = [r'$E_\\mathrm{tot}$', r'$+ E_\\rho$', r'$+ \\nabla$ (ours)', r'$+ H$ (ours)']\n",
    "\n",
    "# Map aggregated model names to plot model names\n",
    "model_name_map = {'NNmGGA': 'NNmGGA', 'XCdiff': 'XC-diff', 'Skala': 'Skala-mGGA'}\n",
    "\n",
    "# Map summary.txt metric names to plot keys\n",
    "metric_name_map = {\n",
    "    'total_energy_mae_mEh': 'E_tot',\n",
    "    'mean_field_mae_mEh': 'E_rho',  # Mean field energy error\n",
    "    'xc_energy_mae_mEh': 'E_xc',\n",
    "    'homo_lumo_gap_mae_mEh': 'Delta_eps_HL',\n",
    "    'dipole_difference_au': 'mu_rho',  # Dipole moment difference\n",
    "    'coulomb_energy_mae_mEh': 'E_C',\n",
    "    'density_L1': 'density_L1',\n",
    "    'density_L2': 'density_L2',\n",
    "}\n",
    "\n",
    "# Create data and errors dicts in the format expected by plotting code\n",
    "data = {}\n",
    "errors = {}\n",
    "\n",
    "for summary_metric, plot_key in metric_name_map.items():\n",
    "    if summary_metric in all_means:\n",
    "        data[plot_key] = {}\n",
    "        errors[plot_key] = {}\n",
    "\n",
    "        for agg_model, plot_model in model_name_map.items():\n",
    "            if agg_model in all_means[summary_metric]:\n",
    "                data[plot_key][plot_model] = all_means[summary_metric][agg_model]\n",
    "                errors[plot_key][plot_model] = all_stds[summary_metric][agg_model]\n",
    "\n",
    "# Add metric labels and units for plotting\n",
    "metric_labels = {\n",
    "    'E_tot': r'$E_\\mathrm{tot}$',\n",
    "    'E_rho': r'$E_\\rho$',\n",
    "    'E_xc': r'$E_\\mathrm{xc}$',\n",
    "    'Delta_eps_HL': r'$\\Delta \\varepsilon_\\mathrm{HL}$',\n",
    "    'mu_rho': r'Dipole $\\mu_\\rho$',\n",
    "    'E_C': r'$E_\\mathrm{C}$',\n",
    "    'density_L1': r'$L_1[\\Delta \\rho]$',\n",
    "    'density_L2': r'$L_2[\\Delta \\rho]$',\n",
    "}\n",
    "\n",
    "metric_units = {\n",
    "    'E_tot': '(MAE mEh)',\n",
    "    'E_rho': '(MAE mEh)',\n",
    "    'E_xc': '(MAE mEh)',\n",
    "    'Delta_eps_HL': '(MAE mEh)',\n",
    "    'mu_rho': '(MAE)',\n",
    "    'E_C': '(MAE mEh)',\n",
    "    'density_L1': '',\n",
    "    'density_L2': '',\n",
    "}\n",
    "\n",
    "# Define the layout:\n",
    "# Row 1: E_tot, E_rho, E_xc, Delta_eps_HL\n",
    "# Row 2: mu_rho (dipole), E_C, density_L1, density_L2\n",
    "row1_metrics = ['E_tot', 'E_rho', 'E_xc', 'Delta_eps_HL']\n",
    "row2_metrics = ['mu_rho', 'E_C', 'density_L1', 'density_L2']\n",
    "all_metrics = row1_metrics + row2_metrics\n",
    "\n",
    "print('Data formatted for plotting!')\n",
    "print(f'\\nAvailable plot keys: {list(data.keys())}')\n",
    "print(f'Models: {models}')\n",
    "print(f'Loss configurations: {losses}')\n",
    "print(f'\\nRow 1 metrics: {row1_metrics}')\n",
    "print(f'Row 2 metrics: {row2_metrics}')\n",
    "print('\\nExample - E_tot data:')\n",
    "for model in models:\n",
    "    print(f'  {model}: {data[\"E_tot\"][model]}')\n",
    "\n",
    "loss_colors = [colors[2], colors[1], colors[0], colors[3]]  # E, E+ρ, E+ρ+∇, E+ρ+∇+H\n",
    "loss_labels = [r'$E$', r'$+ \\rho$', r'$+ \\nabla$ (ours)', r'$+ H$ (ours)']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "c6892d0b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "=== Processing OOD Basis Set Data ===\n",
      "Processing NNmGGA_scan_qm5/ood_basis_set with loss config 0 ($E$), checkpoints (18, 20, 22)\n",
      "Processing NNmGGA_scan_qm5/ood_basis_set with loss config 1 ($E + \\rho$), checkpoints (17, 19, 21)\n",
      "Processing NNmGGA_scan_qm5/ood_basis_set with loss config 2 ($E + \\rho + \\nabla$), checkpoints (24, 26, 28)\n",
      "Processing NNmGGA_scan_qm5/ood_basis_set with loss config 3 ($E + \\rho + \\nabla + H$), checkpoints (23, 25, 27)\n",
      "Processing XCdiff_scan_qm5/ood_basis_set with loss config 0 ($E$), checkpoints (390, 394, 401)\n",
      "Processing XCdiff_scan_qm5/ood_basis_set with loss config 1 ($E + \\rho$), checkpoints (389, 391, 402)\n",
      "Processing XCdiff_scan_qm5/ood_basis_set with loss config 2 ($E + \\rho + \\nabla$), checkpoints (395, 399, 403)\n",
      "Processing XCdiff_scan_qm5/ood_basis_set with loss config 3 ($E + \\rho + \\nabla + H$), checkpoints (396, 398, 400)\n",
      "Processing Skala_mGGA_scan_qm5/ood_basis_set with loss config 0 ($E$), checkpoints (13, 34, 36)\n",
      "Processing Skala_mGGA_scan_qm5/ood_basis_set with loss config 1 ($E + \\rho$), checkpoints (14, 35, 37)\n",
      "Processing Skala_mGGA_scan_qm5/ood_basis_set with loss config 2 ($E + \\rho + \\nabla$), checkpoints (38, 40, 42)\n",
      "Processing Skala_mGGA_scan_qm5/ood_basis_set with loss config 3 ($E + \\rho + \\nabla + H$), checkpoints (39, 41, 43)\n",
      "\n",
      "OOD Data formatted for plotting!\n",
      "Available OOD plot keys: ['E_tot', 'E_rho', 'E_xc', 'Delta_eps_HL', 'mu_rho', 'E_C', 'density_L1', 'density_L2']\n"
     ]
    }
   ],
   "source": [
    "# ===== OOD Basis Set Data =====\n",
    "# Same model batches but pointing to ood_basis_set subdirectories\n",
    "model_batches_ood = [\n",
    "    [  # NNmGGA\n",
    "        ('NNmGGA_scan_qm5/ood_basis_set', None, r'$E$', (18, 20, 22)),\n",
    "        ('NNmGGA_scan_qm5/ood_basis_set', None, r'$E + \\rho$', (17, 19, 21)),\n",
    "        ('NNmGGA_scan_qm5/ood_basis_set', None, r'$E + \\rho + \\nabla$', (24, 26, 28)),\n",
    "        ('NNmGGA_scan_qm5/ood_basis_set', None, r'$E + \\rho + \\nabla + H$', (23, 25, 27)),\n",
    "    ],\n",
    "    [  # XCdiff\n",
    "        ('XCdiff_scan_qm5/ood_basis_set', None, r'$E$', (390, 394, 401)),\n",
    "        ('XCdiff_scan_qm5/ood_basis_set', None, r'$E + \\rho$', (389, 391, 402)),\n",
    "        ('XCdiff_scan_qm5/ood_basis_set', None, r'$E + \\rho + \\nabla$', (395, 399, 403)),\n",
    "        (\n",
    "            'XCdiff_scan_qm5/ood_basis_set',\n",
    "            None,\n",
    "            r'$E + \\rho + \\nabla + H$',\n",
    "            (396, 398, 400),\n",
    "        ),\n",
    "    ],\n",
    "    [  # Skala-mGGA\n",
    "        ('Skala_mGGA_scan_qm5/ood_basis_set', None, r'$E$', (13, 34, 36)),\n",
    "        ('Skala_mGGA_scan_qm5/ood_basis_set', None, r'$E + \\rho$', (14, 35, 37)),\n",
    "        ('Skala_mGGA_scan_qm5/ood_basis_set', None, r'$E + \\rho + \\nabla$', (38, 40, 42)),\n",
    "        (\n",
    "            'Skala_mGGA_scan_qm5/ood_basis_set',\n",
    "            None,\n",
    "            r'$E + \\rho + \\nabla + H$',\n",
    "            (39, 41, 43),\n",
    "        ),\n",
    "    ],\n",
    "]\n",
    "\n",
    "# Aggregate OOD metrics\n",
    "print('\\n=== Processing OOD Basis Set Data ===')\n",
    "all_means_ood, all_stds_ood = aggregate_model_loss_combinations(\n",
    "    checkpoint_root='../evaluations/1000',\n",
    "    model_batches=model_batches_ood,\n",
    "    use_csv=True,\n",
    ")\n",
    "\n",
    "# Format OOD data for plotting\n",
    "data_ood = {}\n",
    "errors_ood = {}\n",
    "\n",
    "for summary_metric, plot_key in metric_name_map.items():\n",
    "    if summary_metric in all_means_ood:\n",
    "        data_ood[plot_key] = {}\n",
    "        errors_ood[plot_key] = {}\n",
    "\n",
    "        for agg_model, plot_model in model_name_map.items():\n",
    "            if agg_model in all_means_ood[summary_metric]:\n",
    "                data_ood[plot_key][plot_model] = all_means_ood[summary_metric][agg_model]\n",
    "                errors_ood[plot_key][plot_model] = all_stds_ood[summary_metric][agg_model]\n",
    "\n",
    "print('\\nOOD Data formatted for plotting!')\n",
    "print(f'Available OOD plot keys: {list(data_ood.keys())}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "4e1ed4ad",
   "metadata": {},
   "outputs": [],
   "source": [
    "# # ===== Plot OOD Basis Set Results =====\n",
    "# fig, axes = plt.subplots(\n",
    "#     2, 4, figsize=(14, 5.5), gridspec_kw={'hspace': 0.08, 'wspace': 0.35}\n",
    "# )\n",
    "# x = np.arange(len(models))\n",
    "# width = 0.20\n",
    "# offsets = [-1.5 * width, -0.5 * width, 0.5 * width, 1.5 * width]\n",
    "\n",
    "# for idx, metric in enumerate(all_metrics):\n",
    "#     row = idx // 4\n",
    "#     col = idx % 4\n",
    "#     ax = axes[row, col]\n",
    "\n",
    "#     # Loop over loss terms (columns) and models (groups within each position)\n",
    "#     for loss_idx in range(len(losses)):\n",
    "#         for model_idx, model in enumerate(models):\n",
    "#             vals = data_ood[metric][model]\n",
    "#             errs = errors_ood[metric][model]\n",
    "\n",
    "#             # Get value and error for this specific loss term\n",
    "#             val = vals[loss_idx]\n",
    "#             err = errs[loss_idx]\n",
    "\n",
    "#             ax.bar(\n",
    "#                 model_idx + offsets[loss_idx],\n",
    "#                 val,\n",
    "#                 width,\n",
    "#                 label=loss_labels[loss_idx] if (idx == 0 and model_idx == 0) else None,\n",
    "#                 color=loss_colors[loss_idx],\n",
    "#                 edgecolor='black',\n",
    "#                 linewidth=0.5,\n",
    "#                 zorder=3,\n",
    "#             )\n",
    "\n",
    "#             ax.errorbar(\n",
    "#                 model_idx + offsets[loss_idx],\n",
    "#                 val,\n",
    "#                 yerr=err,\n",
    "#                 fmt='none',\n",
    "#                 color='0.2',\n",
    "#                 capsize=1.5,\n",
    "#                 capthick=0.6,\n",
    "#                 linewidth=1,\n",
    "#                 zorder=4,\n",
    "#             )\n",
    "\n",
    "#     ax.set_ylabel(f'{metric_labels[metric]} {metric_units[metric]}')\n",
    "#     ax.set_xticks(x)\n",
    "\n",
    "#     # Only show x labels on bottom row (model names)\n",
    "#     if row == 0:\n",
    "#         ax.set_xticklabels([])\n",
    "#     else:\n",
    "#         ax.set_xticklabels(models)\n",
    "\n",
    "#     # Set scales and limits based on metric type (same as in-distribution)\n",
    "#     linthresh = None\n",
    "#     if metric == 'E_tot':\n",
    "#         pass\n",
    "#     elif metric == 'E_rho':\n",
    "#         linthresh = 2\n",
    "#         ax.set_yscale('symlog', linthresh=linthresh, linscale=2)\n",
    "#         ticks = [0, 1, 2, 5, 10, 20, 50, 100]\n",
    "#         labels = [0, 1, 2, 5, 10, 20, 50, '']\n",
    "#         ax.set_yticks(ticks, labels=labels)\n",
    "#     elif metric == 'E_xc':\n",
    "#         linthresh = 5\n",
    "#         ax.set_yscale('symlog', linthresh=linthresh, linscale=1.2)\n",
    "#         ticks = [0, 1, 2, 3, 4, 5, 10, 20, 50, 100]\n",
    "#         labels = [0, 1, 2, 3, 4, 5, 10, 20, 50, 100]\n",
    "#         ax.set_yticks(ticks, labels=labels)\n",
    "#         ax.set_ylim(0, 120)\n",
    "#     elif metric == 'Delta_eps_HL':\n",
    "#         linthresh = 1\n",
    "#         ax.set_yscale('symlog', linthresh=linthresh, linscale=1.2)\n",
    "#         ticks = [0, 0.2, 0.4, 0.6, 0.8, 1, 2, 5, 10, 20]\n",
    "#         labels = [0, 0.2, 0.4, 0.6, 0.8, 1, 2, 5, 10, 20]\n",
    "#         ax.set_yticks(ticks, labels=labels)\n",
    "#         ax.set_ylim(0, 25)\n",
    "#     elif metric == 'mu_rho':\n",
    "#         linthresh = 0.004\n",
    "#         ax.set_yscale('symlog', linthresh=linthresh, linscale=2)\n",
    "#         ticks = [0, 0.001, 0.002, 0.003, 0.004, 0.008, 0.016, 0.032]\n",
    "#         ax.set_yticks(ticks, labels=(1000 * np.array(ticks)).astype(int))\n",
    "#     elif metric == 'E_C':\n",
    "#         linthresh = 5\n",
    "#         ax.set_yscale('symlog', linthresh=linthresh, linscale=1.2)\n",
    "#         ticks = [0, 1, 2, 3, 4, 5, 10, 20, 50, 100, 200, 500]\n",
    "#         labels = [0, 1, 2, 3, 4, 5, 10, 20, 50, 100, 200, 500]\n",
    "#         ax.set_yticks(ticks, labels=labels)\n",
    "#     elif metric == 'density_L1':\n",
    "#         ax.set_yscale('log')\n",
    "#     elif metric == 'density_L2':\n",
    "#         ax.set_yscale('log')\n",
    "\n",
    "#     if linthresh is not None:\n",
    "#         ax.axhline(linthresh, color='0.4', linewidth=1.5, linestyle='-', zorder=1)\n",
    "\n",
    "#     ax.grid(True, axis='y', alpha=0.4, linewidth=0.5, zorder=0)\n",
    "#     ax.grid(False, axis='x')\n",
    "#     ax.set_axisbelow(True)\n",
    "\n",
    "# fig.suptitle('OOD Basis Set Test', fontsize=18, y=0.98)\n",
    "# fig.legend(\n",
    "#     loc='upper center',\n",
    "#     bbox_to_anchor=(0.5, 0.96),\n",
    "#     ncol=4,\n",
    "#     frameon=False,\n",
    "#     columnspacing=1.5,\n",
    "#     handletextpad=0.4,\n",
    "# )\n",
    "# plt.savefig('qm9_scan_comparison_ood.pdf', bbox_inches='tight')\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "b983a5e9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1400x450 with 8 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# ===== Combined Plot: In-Distribution + OOD =====\n",
    "fig, axes = plt.subplots(\n",
    "    2, 4, figsize=(14, 4.5), gridspec_kw={'hspace': 0.04, 'wspace': 0.3}\n",
    ")\n",
    "x = np.arange(len(models))\n",
    "width = 0.20\n",
    "offsets = [-1.5 * width, -0.5 * width, 0.5 * width, 1.5 * width]\n",
    "\n",
    "ALPHA = 1.0\n",
    "\n",
    "for idx, metric in enumerate(all_metrics):\n",
    "    row = idx // 4\n",
    "    col = idx % 4\n",
    "    ax = axes[row, col]\n",
    "\n",
    "    # First plot OOD data in background with transparency and hatching\n",
    "    for loss_idx in range(len(losses)):\n",
    "        for model_idx, model in enumerate(models):\n",
    "            vals_ood = data_ood[metric][model]\n",
    "            errs_ood = errors_ood[metric][model]\n",
    "\n",
    "            val_ood = vals_ood[loss_idx]\n",
    "            err_ood = errs_ood[loss_idx]\n",
    "\n",
    "            ax.bar(\n",
    "                model_idx + offsets[loss_idx],\n",
    "                val_ood,\n",
    "                width,\n",
    "                color='white',\n",
    "                hatch='///',  # White tilted stripes\n",
    "                alpha=ALPHA,\n",
    "                edgecolor=loss_colors[loss_idx],\n",
    "                linewidth=0.5,\n",
    "                zorder=1,\n",
    "            )\n",
    "\n",
    "            # ax.errorbar(\n",
    "            #     model_idx + offsets[loss_idx], val_ood, yerr=err_ood,\n",
    "            #     fmt='none', color='0.5',\n",
    "            #     capsize=1.5, capthick=0.6,\n",
    "            #     linewidth=1, zorder=2,\n",
    "            #     alpha=ALPHA\n",
    "            # )\n",
    "\n",
    "    # Then plot in-distribution data on top\n",
    "    for loss_idx in range(len(losses)):\n",
    "        for model_idx, model in enumerate(models):\n",
    "            vals = data[metric][model]\n",
    "            errs = errors[metric][model]\n",
    "\n",
    "            val = vals[loss_idx]\n",
    "            err = errs[loss_idx]\n",
    "\n",
    "            ax.bar(\n",
    "                model_idx + offsets[loss_idx],\n",
    "                val,\n",
    "                width,\n",
    "                label=loss_labels[loss_idx] if (idx == 0 and model_idx == 0) else None,\n",
    "                color=loss_colors[loss_idx],\n",
    "                edgecolor='black',\n",
    "                linewidth=0.5,\n",
    "                zorder=3,\n",
    "            )\n",
    "\n",
    "            ax.errorbar(\n",
    "                model_idx + offsets[loss_idx],\n",
    "                val,\n",
    "                yerr=err,\n",
    "                fmt='none',\n",
    "                color='0.2',\n",
    "                capsize=1.5,\n",
    "                capthick=0.6,\n",
    "                linewidth=1,\n",
    "                zorder=4,\n",
    "            )\n",
    "\n",
    "    ax.set_ylabel(f'{metric_labels[metric]} {metric_units[metric]}')\n",
    "    ax.set_xticks(x)\n",
    "\n",
    "    # Only show x labels on bottom row (model names)\n",
    "    if row == 0:\n",
    "        ax.set_xticklabels([])\n",
    "    else:\n",
    "        ax.set_xticklabels(models)\n",
    "\n",
    "    # # Set scales and limits (same as individual plots)\n",
    "    linthresh = None\n",
    "    # if metric == 'E_tot':\n",
    "    #     linthresh = 3\n",
    "    #     ax.set_yscale('symlog', linthresh=linthresh, linscale=2)\n",
    "    #     ticks = [0, 1, 2, 5, 10]\n",
    "    #     labels = [0, 1, 2, 5, 10]\n",
    "    #     ax.set_yticks(ticks, labels=labels)\n",
    "    # elif metric == 'E_rho':\n",
    "    #     linthresh = 2\n",
    "    #     ax.set_yscale('symlog', linthresh=linthresh, linscale=2)\n",
    "    #     ticks = [0, 1, 2, 5, 10, 20, 50, 100]\n",
    "    #     labels = [0, 1, 2, 5, 10, 20, 50, '']\n",
    "    #     ax.set_yticks(ticks, labels=labels)\n",
    "    # elif metric == 'E_xc':\n",
    "    #     linthresh = 5\n",
    "    #     ax.set_yscale('symlog', linthresh=linthresh, linscale=1.2)\n",
    "    #     ticks = [0, 1, 2, 3, 4, 5, 10, 20, 50, 100]\n",
    "    #     labels = [0, 1, 2, 3, 4, 5, 10, 20, 50, 100]\n",
    "    #     ax.set_yticks(ticks, labels=labels)\n",
    "    #     ax.set_ylim(0, 120)\n",
    "    # elif metric == 'Delta_eps_HL':\n",
    "    #     linthresh = 1\n",
    "    #     ax.set_yscale('symlog', linthresh=linthresh, linscale=1.2)\n",
    "    #     ticks = [0, 0.2, 0.4, 0.6, 0.8, 1, 2, 5, 10, 20]\n",
    "    #     labels = [0, 0.2, 0.4, 0.6, 0.8, 1, 2, 5, 10, 20]\n",
    "    #     ax.set_yticks(ticks, labels=labels)\n",
    "    #     ax.set_ylim(0, 25)\n",
    "    # elif metric == 'mu_rho':\n",
    "    #     linthresh = 0.004\n",
    "    #     ax.set_yscale('symlog', linthresh=linthresh, linscale=2)\n",
    "    #     ticks = [0, 0.001, 0.002, 0.003, 0.004, 0.008, 0.016, 0.032]\n",
    "    #     ax.set_yticks(ticks, labels=(1000 * np.array(ticks)).astype(int))\n",
    "    # elif metric == 'E_C':\n",
    "    #     linthresh = 5\n",
    "    #     ax.set_yscale('symlog', linthresh=linthresh, linscale=1.2)\n",
    "    #     ticks = [0, 1, 2, 3, 4, 5, 10, 20, 50, 100, 200, 500]\n",
    "    #     labels = [0, 1, 2, 3, 4, 5, 10, 20, 50, 100, 200, 500]\n",
    "    #     ax.set_yticks(ticks, labels=labels)\n",
    "    # elif metric == 'density_L1':\n",
    "    #     ax.set_yscale('log')\n",
    "    # elif metric == 'density_L2':\n",
    "    #     ax.set_yscale('log')\n",
    "\n",
    "    ax.set_yscale('log')\n",
    "\n",
    "    if linthresh is not None:\n",
    "        ax.axhline(linthresh, color='0.4', linewidth=1.5, linestyle='-', zorder=0)\n",
    "\n",
    "    ax.grid(True, axis='y', alpha=0.8, linewidth=0.5, zorder=0)\n",
    "    ax.grid(False, axis='x')\n",
    "    ax.set_axisbelow(True)\n",
    "\n",
    "    ax.yaxis.set_tick_params(pad=18)\n",
    "    for label in ax.get_yticklabels():\n",
    "        label.set_ha('left')\n",
    "\n",
    "# Create custom legend handles for ID and OOD\n",
    "from matplotlib.patches import Patch\n",
    "\n",
    "# Get handles and labels from the first axis (loss terms)\n",
    "handles, labels = axes[0, 0].get_legend_handles_labels()\n",
    "\n",
    "# Add custom patches for ID and OOD\n",
    "id_patch = Patch(facecolor='0.3', edgecolor='black', label='ID basis')\n",
    "ood_patch = Patch(\n",
    "    facecolor='white', hatch='///', edgecolor='0.5', alpha=0.4, label='OOD basis'\n",
    ")\n",
    "\n",
    "# Combine all handles and labels\n",
    "all_handles = handles + [id_patch, ood_patch]\n",
    "all_labels = labels + ['ID basis (def2-TZVPD)', 'OOD basis (def2-SVP)']\n",
    "\n",
    "fig.legend(\n",
    "    all_handles,\n",
    "    all_labels,\n",
    "    loc='upper center',\n",
    "    bbox_to_anchor=(0.5, 0.96),\n",
    "    ncol=6,  # 4 loss terms + 2 basis types\n",
    "    frameon=False,\n",
    "    columnspacing=1.5,\n",
    "    handletextpad=0.4,\n",
    ")\n",
    "plt.savefig('qm9_scan_comparison_combined.pdf', bbox_inches='tight')\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": ".venv",
   "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.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
