{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e10264d63664f1aa",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "from pathlib import Path\n",
    "import importlib\n",
    "\n",
    "BASE_MODULO_PATH = Path(\"path/of/the/folder/where/hephaestus/is/placed\")\n",
    "\n",
    "SAVE_PATH = BASE_MODULO_PATH / \"excluded\" / \"hephaestus_storage_unit\" / \"plots\" / \"stats_synth_dataset\"\n",
    "SAVE_PATH.mkdir(exist_ok=True, parents=True)\n",
    "\n",
    "DETERMINISTIC_DATA_PATH = Path(\n",
    "    \"path/to/where/v2.tar.xz/was/extracted\"\n",
    ")\n",
    "NON_DETERMINISTIC_DATA_PATH = Path(\n",
    "    \"path/to/where/v1_missing_parts.tar.xz/was/extracted\"\n",
    ")\n",
    "DETERMINISTIC_LABELS_PATH = DETERMINISTIC_DATA_PATH / \"v2\" / \"labels\"\n",
    "NON_DETERMINISTIC_LABELS_PATH = NON_DETERMINISTIC_DATA_PATH / \"v1_missing_parts\" / \"labels\"\n",
    "\n",
    "os.chdir(BASE_MODULO_PATH)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "initial_id",
   "metadata": {},
   "outputs": [],
   "source": [
    "import networkx as nx\n",
    "\n",
    "import pandas as pd\n",
    "\n",
    "import torch\n",
    "import numpy as np\n",
    "\n",
    "import seaborn as sns\n",
    "from matplotlib import pyplot as plt\n",
    "\n",
    "import hephaestus.utils.general_utils as hutils\n",
    "import hephaestus.utils.load_general_config as hconf\n",
    "\n",
    "pd.options.mode.chained_assignment = None  # default='warn'\n",
    "\n",
    "sns.set_context(\"paper\", font_scale=2)\n",
    "sns.set_style(\"whitegrid\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5c4149f4",
   "metadata": {},
   "outputs": [],
   "source": [
    "rng = np.random.default_rng(42)\n",
    "\n",
    "\n",
    "def reload_hephaestus_modules():\n",
    "    importlib.reload(hutils)\n",
    "\n",
    "\n",
    "def roundup(x):\n",
    "    return np.ceil(x / 10.0) * 10"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "585bd87f",
   "metadata": {},
   "outputs": [],
   "source": [
    "p = [\n",
    "    \"#000000\",\n",
    "    \"#E69F00\",\n",
    "    \"#56B4E9\",\n",
    "    \"#009E73\",\n",
    "    \"#FB6467FF\",\n",
    "    \"#808282\",\n",
    "    \"#F0E442\",\n",
    "    \"#440154FF\",\n",
    "    \"#0072B2\",\n",
    "    \"#D55E00\",\n",
    "    \"#CC79A7\",\n",
    "    \"#C2CD23\",\n",
    "    \"#918BC3\",\n",
    "    \"#FFFFFF\",\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ae18630d",
   "metadata": {},
   "outputs": [],
   "source": [
    "sns.color_palette(p)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "eb4d121a",
   "metadata": {},
   "source": [
    "## Nodes and Edges"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1cdc6a7060171713",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_stats = pd.read_csv(DETERMINISTIC_DATA_PATH / \"v2\" / \"stats_deterministic.csv\")\n",
    "\n",
    "gen_to_remove = set()\n",
    "for gen in df_stats[\"GraphNames\"].unique():\n",
    "    if hutils.get_dataset_name(gen) not in list(hconf.DETERMINISTIC_DATA.values()):\n",
    "        gen_to_remove.add(hutils.get_dataset_name(gen))\n",
    "\n",
    "for gen in gen_to_remove:\n",
    "    df_stats = df_stats[~df_stats[\"GraphNames\"].str.contains(\"HYPERCUBE\")]\n",
    "    df_stats.reset_index(inplace=True, drop=True)\n",
    "    df_stats[\"GenType\"] = \"Deterministic\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b2b67626",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_list = []\n",
    "for f in os.listdir(NON_DETERMINISTIC_DATA_PATH / \"v1_missing_parts\"):\n",
    "    if \".csv\" in f:\n",
    "        stat = pd.read_csv(NON_DETERMINISTIC_DATA_PATH / \"v1_missing_parts\" / f)\n",
    "        if f == \"NDeterministicGen_stats_1.csv\":\n",
    "            stat = stat[\n",
    "                ~stat[\"GraphNames\"].apply(lambda x: \"REGULAR\" in x)\n",
    "            ].reset_index(drop=True)\n",
    "\n",
    "        if f == \"NDeterministicGen_stats_3.csv\":\n",
    "            stat = stat[\n",
    "                ~stat[\"GraphNames\"].apply(lambda x: \"hephaestus\" in x)\n",
    "            ].reset_index(drop=True)\n",
    "\n",
    "        stat[\"GenType\"] = \"Non Deterministic\"\n",
    "        df_list.append(stat)\n",
    "\n",
    "df_stats_nd = pd.concat(df_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2ab639f8",
   "metadata": {},
   "outputs": [],
   "source": [
    "all_df_stats = pd.concat([df_stats_nd, df_stats])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d8f9e419",
   "metadata": {},
   "outputs": [],
   "source": [
    "pretty_names = all_df_stats[\"GraphNames\"].apply(hutils.get_pretty_graph_name)\n",
    "dataset_names = all_df_stats[\"GraphNames\"].apply(hutils.get_dataset_name)\n",
    "\n",
    "all_df_stats[\"GraphNames\"] = pretty_names\n",
    "\n",
    "dataset_names = sorted(dataset_names.unique())\n",
    "pretty_names = sorted(pretty_names.unique())\n",
    "\n",
    "gen_dataset_dict = dict(\n",
    "    [(i, dn) for i, dn in zip(range(len(dataset_names)), dataset_names)]\n",
    ")\n",
    "pretty_gen_graph_dict = dict(\n",
    "    [(i, gn) for i, gn in zip(range(len(pretty_names)), pretty_names)]\n",
    ")\n",
    "\n",
    "mean_nodes = all_df_stats.groupby(\"GraphNames\")[\"NumberNodes\"].mean().apply(roundup)\n",
    "mean_edges = all_df_stats.groupby(\"GraphNames\")[\"NumberOfEdges\"].mean().apply(roundup)\n",
    "\n",
    "all_df_stats[\"MeanNodes\"] = all_df_stats[\"GraphNames\"].map(mean_nodes)\n",
    "all_df_stats[\"MeanEdges\"] = all_df_stats[\"GraphNames\"].map(mean_edges)\n",
    "\n",
    "\n",
    "max_nodes = all_df_stats.groupby(\"GraphNames\")[\"NumberNodes\"].max().apply(roundup)\n",
    "max_edges = all_df_stats.groupby(\"GraphNames\")[\"NumberOfEdges\"].max().apply(roundup)\n",
    "\n",
    "all_df_stats[\"MaxNodes\"] = all_df_stats[\"GraphNames\"].map(max_nodes)\n",
    "all_df_stats[\"MaxEdges\"] = all_df_stats[\"GraphNames\"].map(max_edges)\n",
    "\n",
    "\n",
    "min_nodes = all_df_stats.groupby(\"GraphNames\")[\"NumberNodes\"].min().apply(roundup)\n",
    "min_edges = all_df_stats.groupby(\"GraphNames\")[\"NumberOfEdges\"].min().apply(roundup)\n",
    "\n",
    "all_df_stats[\"MinNodes\"] = all_df_stats[\"GraphNames\"].map(min_nodes)\n",
    "all_df_stats[\"MinEdges\"] = all_df_stats[\"GraphNames\"].map(min_edges)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "72d6cd21",
   "metadata": {},
   "outputs": [],
   "source": [
    "all_df_stats[\"GraphNames\"] = all_df_stats[\"GraphNames\"].map(\n",
    "    lambda x: x if x != \"Fast Gnp Random Graph\" else \"Erdos-Renyi\"\n",
    ")\n",
    "all_df_stats[\"GraphNames\"] = all_df_stats[\"GraphNames\"].map(\n",
    "    lambda x: x if x != \"Grid Graph\" else \"Square Lattice\"\n",
    ")\n",
    "all_df_stats[\"GraphNames\"] = all_df_stats[\"GraphNames\"].map(\n",
    "    lambda x: x if x != \"Random Limited 3Dgeo Dd Graph\" else \"Geometric-3D DD Graph\"\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c3ec9328",
   "metadata": {},
   "outputs": [],
   "source": [
    "print(\"Minimum Stats\")\n",
    "print(\"Nodes (Used in stats for the real dataset)\")\n",
    "print(all_df_stats[\"MinNodes\"].min())\n",
    "print(all_df_stats[\"MinNodes\"].mean(), \" <------ Value used\")\n",
    "print(all_df_stats[\"MinNodes\"].max())\n",
    "\n",
    "print(\"\\nEdges (Used in stats for the real dataset)\")\n",
    "print(all_df_stats[\"MinEdges\"].min())\n",
    "print(all_df_stats[\"MinEdges\"].mean(), \" <------ Value used\")\n",
    "print(all_df_stats[\"MinEdges\"].max())\n",
    "\n",
    "##################################################################\n",
    "##################################################################\n",
    "\n",
    "print(\"\\n----------------------------------------------------------------\")\n",
    "print(\"Mean Stats\")\n",
    "print(\"Nodes (Used in stats for the real dataset)\")\n",
    "print(all_df_stats[\"MeanNodes\"].min())\n",
    "print(all_df_stats[\"MeanNodes\"].mean(), \" <------ Value used\")\n",
    "print(all_df_stats[\"MeanNodes\"].max())\n",
    "\n",
    "print(\"\\nEdges (Used in stats for the real dataset)\")\n",
    "print(all_df_stats[\"MeanEdges\"].min())\n",
    "print(all_df_stats[\"MeanEdges\"].mean(), \" <------ Value used\")\n",
    "print(all_df_stats[\"MeanEdges\"].max())\n",
    "\n",
    "##################################################################\n",
    "##################################################################\n",
    "\n",
    "print(\"\\n----------------------------------------------------------------\")\n",
    "print(\"Max Stats\")\n",
    "print(\"Nodes (Used in stats for the real dataset)\")\n",
    "print(all_df_stats[\"MaxNodes\"].min())\n",
    "print(all_df_stats[\"MaxNodes\"].mean(), \" <------ Value used\")\n",
    "print(all_df_stats[\"MaxNodes\"].max())\n",
    "\n",
    "print(\"\\nEdges (Used in stats for the real dataset)\")\n",
    "print(all_df_stats[\"MaxEdges\"].min())\n",
    "print(all_df_stats[\"MaxEdges\"].mean(), \" <------ Value used\")\n",
    "print(all_df_stats[\"MaxEdges\"].max())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "66d795c0",
   "metadata": {},
   "outputs": [],
   "source": [
    "all_df_stats_melted = pd.melt(\n",
    "    all_df_stats,\n",
    "    id_vars=[\"GraphNames\", \"MeanNodes\", \"MeanEdges\"],\n",
    "    value_vars=[\"NumberNodes\", \"NumberOfEdges\"],\n",
    "    var_name=\"RawCountType\",\n",
    "    value_name=\"Value\",\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6f102b38",
   "metadata": {},
   "outputs": [],
   "source": [
    "sns.set_context(\"poster\", font_scale=1)\n",
    "g = sns.catplot(\n",
    "    data=all_df_stats_melted,\n",
    "    x=\"RawCountType\",\n",
    "    y=\"Value\",\n",
    "    col=\"GraphNames\",\n",
    "    kind=\"violin\",\n",
    "    inner_kws=dict(box_width=15, whis_width=2),\n",
    "    hue=\"RawCountType\",\n",
    "    col_wrap=4,\n",
    "    aspect=28 / 20,\n",
    "    sharey=False,\n",
    "    palette=p[1:3],\n",
    ")\n",
    "\n",
    "g.set_xlabels(\"\")\n",
    "g.set_titles(col_template=\"{col_name}\", fontweight=\"bold\")\n",
    "g.despine(left=True)\n",
    "plt.tight_layout()\n",
    "plt.savefig(SAVE_PATH/'node_edges.pdf', dpi=1200)\n",
    "plt.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "df6a5e14acf1dd4b",
   "metadata": {},
   "outputs": [],
   "source": [
    "print(f\"{all_df_stats['NumberNodes'].sum():,} nodes present.\")\n",
    "\n",
    "print(f\"{all_df_stats['NumberOfEdges'].sum():,} edges present.\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e4de87b9",
   "metadata": {},
   "source": [
    "---\n",
    "\n",
    "## See Data - All together"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7d513436",
   "metadata": {},
   "outputs": [],
   "source": [
    "cols = []\n",
    "new_col_names = {}\n",
    "for i in range(hconf.NUM_SUBGRAPHS):\n",
    "    base = \"Subgraph\" + str(i)\n",
    "    original = base\n",
    "    if i == 0:\n",
    "        base += \" (3-path)\"\n",
    "    elif i == 1:\n",
    "        base += \" (3-clique)\"\n",
    "    elif i == 2:\n",
    "        base += \" (4-path)\"\n",
    "    elif i == 3:\n",
    "        base += \" (4-cycle)\"\n",
    "    elif i == 4:\n",
    "        base += \" (4-star)\"\n",
    "    elif i == 5:\n",
    "        base += \" (tri-pan)\"\n",
    "    elif i == 6:\n",
    "        base += \" (bi-pan)\"\n",
    "    elif i == 7:\n",
    "        base += \" (4-clique)\"\n",
    "    cols.append(base)\n",
    "    new_col_names[original] = base\n",
    "\n",
    "subgraph_names = range(len(cols))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6f0455e89bebd23d",
   "metadata": {},
   "outputs": [],
   "source": [
    "dgen_data = hconf.DETERMINISTIC_DATA\n",
    "ndgen_data = hconf.NDETERMINISTIC_DATA\n",
    "\n",
    "dfs = {}\n",
    "for d in os.listdir(DETERMINISTIC_LABELS_PATH):\n",
    "    dataset_name = hutils.get_dataset_name(d, has_file_identifier=True)\n",
    "    if \"csv\" not in d or dataset_name not in list(dgen_data.values()):\n",
    "        continue\n",
    "    print(d)\n",
    "    data = pd.read_csv(os.path.join(DETERMINISTIC_LABELS_PATH, d))\n",
    "    data.dropna(\n",
    "        subset=[\n",
    "            \"Subgraph0\",\n",
    "            \"Subgraph1\",\n",
    "            \"Subgraph2\",\n",
    "            \"Subgraph3\",\n",
    "            \"Subgraph4\",\n",
    "            \"Subgraph5\",\n",
    "            \"Subgraph6\",\n",
    "            \"Subgraph7\",\n",
    "        ],\n",
    "        inplace=True\n",
    "    )\n",
    "    data = data.rename(columns=new_col_names)\n",
    "    dfs[dataset_name] = data\n",
    "\n",
    "for d in os.listdir(NON_DETERMINISTIC_LABELS_PATH):\n",
    "    dataset_name = hutils.get_dataset_name(d, has_file_identifier=True)\n",
    "    if \"csv\" not in d or dataset_name not in list(ndgen_data.values()):\n",
    "        continue\n",
    "    print(d)\n",
    "    data = pd.read_csv(os.path.join(NON_DETERMINISTIC_LABELS_PATH, d))\n",
    "    data.dropna(\n",
    "        subset=[\n",
    "            \"Subgraph0\",\n",
    "            \"Subgraph1\",\n",
    "            \"Subgraph2\",\n",
    "            \"Subgraph3\",\n",
    "            \"Subgraph4\",\n",
    "            \"Subgraph5\",\n",
    "            \"Subgraph6\",\n",
    "            \"Subgraph7\",\n",
    "        ],\n",
    "        inplace=True\n",
    "    )\n",
    "    data = data.rename(columns=new_col_names)\n",
    "    dfs[dataset_name] = data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a0a68674870457df",
   "metadata": {},
   "outputs": [],
   "source": [
    "concatenated_df = []\n",
    "concatenated_df_not_melted = []\n",
    "for gen in dfs.keys():\n",
    "    pd_data = pd.melt(dfs[gen], id_vars=[\"GraphName\", \"OldTarget\"], value_vars=cols,\n",
    "                      var_name=\"Type\", value_name=\"Norm_Z_Score\")\n",
    "\n",
    "    pd_data[\"DatasetName\"] = [gen] * pd_data.shape[0]\n",
    "    try:\n",
    "        dfs[gen].insert(1, \"DatasetName\", [gen] * dfs[gen].shape[0])\n",
    "    except ValueError:\n",
    "        pass\n",
    "\n",
    "    concatenated_df.append(pd_data)\n",
    "    concatenated_df_not_melted.append(dfs[gen])\n",
    "\n",
    "concatenated_df = pd.concat(concatenated_df, ignore_index=True)\n",
    "concatenated_df_not_melted = pd.concat(\n",
    "    concatenated_df_not_melted, ignore_index=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d54c1310",
   "metadata": {},
   "source": [
    "## Grid Figure - All Datasets with Custom Band for Z-score and Strip Plots"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "90c9200a",
   "metadata": {},
   "outputs": [],
   "source": [
    "sampled_conc_df = []\n",
    "for dataset_name in concatenated_df_not_melted[\"DatasetName\"].unique():\n",
    "    bal = concatenated_df_not_melted[\n",
    "        concatenated_df_not_melted[\"DatasetName\"] == dataset_name\n",
    "    ]\n",
    "    bal = bal.iloc[:, :] # rng.integers(0, bal.shape[0], 100)\n",
    "    bal_melted = pd.melt(\n",
    "        bal,\n",
    "        id_vars=[\"GraphName\", \"DatasetName\"],\n",
    "        value_vars=cols,\n",
    "        var_name=\"Type\",\n",
    "        value_name=\"Norm_Z_Score\",\n",
    "    )\n",
    "    sampled_conc_df.append(bal_melted)\n",
    "sampled_conc_df = pd.concat(sampled_conc_df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e21a58cc",
   "metadata": {},
   "outputs": [],
   "source": [
    "sampled_conc_df[\"DatasetName\"] = sampled_conc_df[\"GraphName\"].apply(hutils.get_pretty_graph_name)\n",
    "sampled_conc_df[\"DatasetName\"] = sampled_conc_df[\"DatasetName\"].map(\n",
    "    lambda x: x if x != \"Fast Gnp Random Graph\" else \"Erdos-Renyi\"\n",
    ")\n",
    "sampled_conc_df[\"DatasetName\"] = sampled_conc_df[\"DatasetName\"].map(\n",
    "    lambda x: x if x != \"Grid Graph\" else \"Square Lattice\"\n",
    ")\n",
    "sampled_conc_df[\"DatasetName\"] = sampled_conc_df[\"DatasetName\"].map(\n",
    "    lambda x: x if x != \"Random Limited 3Dgeo Dd Graph\" else \"Geometric-3D DD Graph\"\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4ddac547",
   "metadata": {},
   "outputs": [],
   "source": [
    "sns.set_context(\"paper\", font_scale=1)\n",
    "\n",
    "g = sns.FacetGrid(\n",
    "    sampled_conc_df.iloc[: (8 * 12 * 3200)],\n",
    "    col=\"Type\",\n",
    "    col_wrap=3,\n",
    "    sharey=True,\n",
    "    sharex=True,\n",
    "    aspect=19 / 11,\n",
    ")\n",
    "\n",
    "g.set_titles(col_template=\"{col_name}\", fontweight=\"bold\")\n",
    "g.map_dataframe(\n",
    "    sns.stripplot,\n",
    "    x=\"Norm_Z_Score\",\n",
    "    y=\"DatasetName\",\n",
    "    # hue=\"DatasetName\",\n",
    "    color=p[1],\n",
    "    alpha=0.3,\n",
    "    jitter=True,\n",
    ")\n",
    "g.set_ylabels(\"\")\n",
    "g.set_xlabels(\"Norm Z-score\")\n",
    "\n",
    "g.despine(left=True)\n",
    "plt.tight_layout()\n",
    "plt.savefig(SAVE_PATH/'d_z-score_strip.png', dpi=600)\n",
    "plt.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "edce3662",
   "metadata": {},
   "outputs": [],
   "source": [
    "sns.set_context(\"paper\", font_scale=1)\n",
    "\n",
    "g = sns.FacetGrid(\n",
    "    sampled_conc_df.iloc[(8 * 12 * 3200) + 1 :],\n",
    "    col=\"Type\",\n",
    "    hue=\"DatasetName\",\n",
    "    col_wrap=3,\n",
    "    sharey=True,\n",
    "    sharex=True,\n",
    "    aspect=19 / 11,\n",
    ")\n",
    "\n",
    "g.set_titles(col_template=\"{col_name}\", fontweight=\"bold\")\n",
    "g.map_dataframe(\n",
    "    sns.stripplot,\n",
    "    x=\"Norm_Z_Score\",\n",
    "    y=\"DatasetName\",\n",
    "    color=p[1],\n",
    "    alpha=0.3,\n",
    "    jitter=True,\n",
    ")\n",
    "\n",
    "g.set_ylabels(\"\")\n",
    "g.set_xlabels(\"Norm Z-score\")\n",
    "\n",
    "g.despine(left=True)\n",
    "plt.tight_layout()\n",
    "plt.savefig(SAVE_PATH/'nd_z-score_strip.png', dpi=600)\n",
    "plt.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e6c154b2",
   "metadata": {},
   "outputs": [],
   "source": [
    "sns.set_context(\"paper\", font_scale=2)\n",
    "\n",
    "g = sns.FacetGrid(\n",
    "    sampled_conc_df,\n",
    "    col=\"DatasetName\",\n",
    "    col_wrap=4,\n",
    "    sharey=True,\n",
    "    sharex=True,\n",
    "    aspect=19 / 11,\n",
    ")\n",
    "g.set_titles(col_template=\"{col_name}\")\n",
    "g.set(xticks=subgraph_names)\n",
    "g.set_xticklabels(subgraph_names)\n",
    "g.tick_params(axis=\"x\", which=\"major\", pad=0)\n",
    "g.map_dataframe(\n",
    "    sns.lineplot,\n",
    "    x=\"Type\",\n",
    "    y=\"Norm_Z_Score\",\n",
    "    # hue=\"GraphName\",\n",
    "    alpha=1,\n",
    "    estimator=\"mean\",\n",
    "    color=p[2],\n",
    "    markeredgecolor=p[0],\n",
    "    errorbar=\"pi\",\n",
    "    marker=\"o\",\n",
    ")\n",
    "g.set_xlabels(\"Graph Type\")\n",
    "g.set_ylabels(\"Norm Z-Score\")\n",
    "g.fig.suptitle(\"Band of [2.5, 97.5] Percentiles\")\n",
    "g.fig.subplots_adjust(top=0.92)\n",
    "\n",
    "sns.despine(left=True)\n",
    "plt.tight_layout()\n",
    "plt.savefig(SAVE_PATH/\"separated_percentiles_band.pdf\", dpi=1200)\n",
    "plt.close()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "661a4bdf",
   "metadata": {},
   "source": [
    "---"
   ]
  }
 ],
 "metadata": {
  "language_info": {
   "name": "python"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
