{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "from tbparse import SummaryReader\n",
    "import pandas as pd\n",
    "import os\n",
    "pd.set_option('expand_frame_repr', False)\n",
    "pd.set_option('display.max_colwidth', None)\n",
    "\n",
    "def read_runs(runs, run_path='runs', tags=[]):\n",
    "    ans = pd.DataFrame()\n",
    "    for log_dir in runs:\n",
    "        reader = SummaryReader(os.path.join(run_path,log_dir))\n",
    "        df = reader.scalars\n",
    "        hp = dict(reader.hparams.values)\n",
    "        if 'tag' not in df:\n",
    "            continue\n",
    "        unseen_data = df[(df['step'] == 0) & (\n",
    "            df['tag'].str.startswith('Unseen_0/test'))]\n",
    "        final_step = df[(df['tag'].str.startswith(\n",
    "            'Train/test_avg_loss'))].iloc[-1]['step']\n",
    "        num_step = 800\n",
    "        if final_step == num_step*5:\n",
    "            hp['algorithm'] = 'centralized'\n",
    "        elif final_step != num_step:\n",
    "            continue\n",
    "        final_train_data = df[(df['step'] == final_step)\n",
    "                              & (df['tag'].str.startswith('Train'))]\n",
    "        data = pd.concat([final_train_data, unseen_data],\n",
    "                         axis=0, ignore_index=True)\n",
    "        a = ['save_path', 'data_name','algorithm']\n",
    "        b = [hp['save_path'], hp['data_name'], hp['algorithm']]\n",
    "        fix_dp = pd.DataFrame({'tag': a, 'value': b})\n",
    "        a = hp.keys()\n",
    "        b = hp.values()\n",
    "        head = pd.DataFrame({'tag': a, 'value': b})\n",
    "        data = pd.concat([fix_dp, head, data])\n",
    "        result = data.drop('step', axis=1).T\n",
    "        result.columns = result.iloc[0]\n",
    "        result = result[1:]\n",
    "        result = result.loc[:, ~result.columns.duplicated()].copy()\n",
    "        ans = pd.concat([ans, result], axis=0, ignore_index=True)\n",
    "    return ans\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "tags = ['algorithm', 'seed', 'adv_ratio', 'Train/test_avg_acc', 'Train/test_std_acc',\n",
    "        'Unseen_0/test_avg_acc', 'Unseen_0/test_std_acc']\n",
    "run_path = './runs/DG60'\n",
    "ans = read_runs(os.listdir(run_path), run_path, tags)\n",
    "sorted_result = ans[tags].sort_values(['seed', 'adv_ratio', 'algorithm'])\n",
    "print(sorted_result)\n",
    "sorted_result.to_csv(\"./runs/DG60/results.csv\")\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "gnn",
   "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.10.11"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
