{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0",
   "metadata": {},
   "outputs": [],
   "source": [
    "import statistics\n",
    "\n",
    "import numpy as np\n",
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1",
   "metadata": {},
   "outputs": [],
   "source": [
    "# after running ./scripts/run_clustering.sh\n",
    "# results read from../../results_paper/res_e0/$EXPERIMENT_IDF$/$BASE_PARAMS_IDF$/tikzfiles/change/\n",
    "path_prefix = \"../../results_paper/\""
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2",
   "metadata": {},
   "source": [
    "### Line Plots \"Discovering Mixing Structure\" (Fig. 4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3",
   "metadata": {},
   "outputs": [],
   "source": [
    "from src.exp.config import exp_default_parameters, ExpType\n",
    "from src.exp.gen.generate import NoiseType, IvType, FunType, DagType, IvMode, GSType\n",
    "from matplotlib import pyplot as plt\n",
    "import os\n",
    "import pandas as pd\n",
    "\n",
    "def show_mixing_line(exp, params, attribute, metric=\"node-aris\", path_prefix=os.path.join(path_prefix, \"res_e0/\")):\n",
    "    pth = os.path.join(path_prefix,  f\"MIX_F_{exp['F'].value}_NS_{exp['NS'].value}_DG_{exp['DG'].value}_IVT_{exp['IVT'].value}_IVM_{exp['IVM'].value}_GS_{exp['GS']}/tikzfiles/change/N_{params['N']}_S_{params['S']}_P_{params['P']}_C_{params['C']}_K_{params['K']}_PZ_{params['PZ']}_NZ_{params['NZ']}\")\n",
    "    methods = ['trueGhatZmixLin','topic-mixtureshatGhatZmixLin', 'skipclusSpectral', 'skipclusKmeans', 'skipclusDBSCAN', 'skipclusGMM', 'skipclusGMMglobal']\n",
    "    method_names = ['OURS, trueG','OURS, hatG', 'Spectral (each node)', 'Kmeans (each node)', 'DBSCAN (each node)', 'GMM (each node)', 'GMM']\n",
    "    plt.figure(figsize=(6, 5))\n",
    "    for mth in methods:\n",
    "        tb = pd.read_csv(os.path.join(pth, f'change_{attribute}_m_{mth}.tsv'), sep='\\t')\n",
    "        tb[f'{metric}_mn'].plot()\n",
    "    plt.legend(method_names)\n",
    "    plt.title(f\"change {attribute}\")\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4",
   "metadata": {},
   "outputs": [],
   "source": [
    "from src.exp.config import exp_base_parameters\n",
    "experiment = { 'NS': NoiseType.GAUSS, 'F': FunType.LIN, 'DG': DagType.ERDOS, 'IVT': IvType.COEF, 'IVM': IvMode.MIXING , 'GS': GSType.GRAPH }\n",
    "params = exp_base_parameters(ExpType.CLUSTERING)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5",
   "metadata": {},
   "outputs": [],
   "source": [
    "show_mixing_line(experiment, params, \"C\")\n",
    "show_mixing_line(experiment, params, \"K\")\n",
    "show_mixing_line(experiment, params, \"N\")\n",
    "show_mixing_line(experiment, params, \"S\")\n",
    "show_mixing_line(experiment, params, \"PZ\")\n",
    "show_mixing_line(experiment, params, \"NZ\")"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
