{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import glob\n",
    "import matplotlib.pyplot as plt\n",
    "import os\n",
    "import pandas as pd\n",
    "import seaborn as sns\n",
    "sns.set_theme(style=\"white\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "def parse_csv(path_pattern, labels):\n",
    "    df = pd.DataFrame()\n",
    "    path_list_ML = glob.glob(path_pattern)\n",
    "    path_list_ML.sort()\n",
    "    for path, label in zip(path_list_ML, labels):\n",
    "        df_cur = pd.read_csv(path)\n",
    "        df_cur['alg'] = label\n",
    "        df = pd.concat([df, df_cur], axis=0)\n",
    "    df.index = range(len(df))\n",
    "    return df\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "labels = ['LazyFast', 'Lazy', 'Fast', 'Naive']\n",
    "path_to_data = '#../result/'\n",
    "path_to_out = 'graph/'\n",
    "alg = 'greedy'\n",
    "dataset_name = 'movie_len'\n",
    "input_matrix = 'B'\n",
    "x_axis = 'k'\n",
    "y_axis = 'time'\n",
    "\n",
    "path_pattern = f'{path_to_data}{alg}/{dataset_name}/*-{input_matrix}*.csv'\n",
    "df = parse_csv(path_pattern, labels)\n",
    "fig = plt.figure()\n",
    "graph = sns.lineplot(data=df, x=x_axis, y=y_axis, style='alg', hue='alg', palette='tab10')\n",
    "graph.legend()\n",
    "\n",
    "os.makedirs(path_to_out, exist_ok=True)\n",
    "fig.savefig(\n",
    "    f'{path_to_out}{alg}_{dataset_name}_{y_axis}_{input_matrix}.pdf')"
   ]
  }
 ],
 "metadata": {
  "interpreter": {
   "hash": "06e75bb08dfe89f79c2990a5579740cd6d2ed8904ec17e16043d8d528483c445"
  },
  "kernelspec": {
   "display_name": "Python 3.9.7 ('venv': 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.9.7"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
