{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "5a4db030",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from ast import literal_eval"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "b6a41718",
   "metadata": {},
   "outputs": [],
   "source": [
    "def reading_result(fpath, dataset):\n",
    "    with open('./compare_result/' + fpath + '.txt', 'r') as f:\n",
    "        all_results = f.read()\n",
    "\n",
    "    all_results = all_results.replace('np.float32(', '').replace(')', '')\n",
    "    all_results = literal_eval(all_results)  \n",
    "\n",
    "    ind_list = [dataset]\n",
    "    show_list = ['psnr', 'sndr', 'nrmse']\n",
    "    \n",
    "    for ind in map(str, ind_list):  \n",
    "        row_parts = []\n",
    "        for metric in show_list:\n",
    "            mean1 = all_results[ind][f\"{metric}_mean\"]\n",
    "            std1 = all_results[ind][f\"{metric}_std\"]\n",
    "            mean2 = all_results[ind][f\"{metric}_mid_mean\"]\n",
    "            std2 = all_results[ind][f\"{metric}_mid_std\"]\n",
    "            row_parts.append(f\"{mean1:.2f} $\\\\pm$ {std1:.2f} / {mean2:.2f} $\\\\pm$ {std2:.2f}\")\n",
    "            \n",
    "        print(\" & \".join(row_parts))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "7c85f4e3-adb0-4fe2-b769-91b84222e966",
   "metadata": {},
   "outputs": [
    {
     "ename": "FileNotFoundError",
     "evalue": "[Errno 2] No such file or directory: './compare_result/aefp.txt'",
     "output_type": "error",
     "traceback": [
      "\u001b[31m---------------------------------------------------------------------------\u001b[39m",
      "\u001b[31mFileNotFoundError\u001b[39m                         Traceback (most recent call last)",
      "\u001b[36mCell\u001b[39m\u001b[36m \u001b[39m\u001b[32mIn[4]\u001b[39m\u001b[32m, line 4\u001b[39m\n\u001b[32m      1\u001b[39m compare_list = [\u001b[33m'\u001b[39m\u001b[33maefp\u001b[39m\u001b[33m'\u001b[39m, \u001b[33m'\u001b[39m\u001b[33maeq1p4\u001b[39m\u001b[33m'\u001b[39m, \u001b[33m'\u001b[39m\u001b[33mvqvae\u001b[39m\u001b[33m'\u001b[39m, \u001b[33m'\u001b[39m\u001b[33mbnn\u001b[39m\u001b[33m'\u001b[39m]\n\u001b[32m      3\u001b[39m \u001b[38;5;28;01mfor\u001b[39;00m i \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mrange\u001b[39m (\u001b[38;5;28mlen\u001b[39m(compare_list)):\n\u001b[32m----> \u001b[39m\u001b[32m4\u001b[39m     \u001b[43mreading_result\u001b[49m\u001b[43m(\u001b[49m\u001b[43mcompare_list\u001b[49m\u001b[43m[\u001b[49m\u001b[43mi\u001b[49m\u001b[43m]\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[32;43m0\u001b[39;49m\u001b[43m)\u001b[49m\n",
      "\u001b[36mCell\u001b[39m\u001b[36m \u001b[39m\u001b[32mIn[2]\u001b[39m\u001b[32m, line 2\u001b[39m, in \u001b[36mreading_result\u001b[39m\u001b[34m(fpath, dataset)\u001b[39m\n\u001b[32m      1\u001b[39m \u001b[38;5;28;01mdef\u001b[39;00m\u001b[38;5;250m \u001b[39m\u001b[34mreading_result\u001b[39m(fpath, dataset):\n\u001b[32m----> \u001b[39m\u001b[32m2\u001b[39m     \u001b[38;5;28;01mwith\u001b[39;00m \u001b[38;5;28;43mopen\u001b[39;49m\u001b[43m(\u001b[49m\u001b[33;43m'\u001b[39;49m\u001b[33;43m./compare_result/\u001b[39;49m\u001b[33;43m'\u001b[39;49m\u001b[43m \u001b[49m\u001b[43m+\u001b[49m\u001b[43m \u001b[49m\u001b[43mfpath\u001b[49m\u001b[43m \u001b[49m\u001b[43m+\u001b[49m\u001b[43m \u001b[49m\u001b[33;43m'\u001b[39;49m\u001b[33;43m.txt\u001b[39;49m\u001b[33;43m'\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[33;43m'\u001b[39;49m\u001b[33;43mr\u001b[39;49m\u001b[33;43m'\u001b[39;49m\u001b[43m)\u001b[49m \u001b[38;5;28;01mas\u001b[39;00m f:\n\u001b[32m      3\u001b[39m         all_results = f.read()\n\u001b[32m      5\u001b[39m     all_results = all_results.replace(\u001b[33m'\u001b[39m\u001b[33mnp.float32(\u001b[39m\u001b[33m'\u001b[39m, \u001b[33m'\u001b[39m\u001b[33m'\u001b[39m).replace(\u001b[33m'\u001b[39m\u001b[33m)\u001b[39m\u001b[33m'\u001b[39m, \u001b[33m'\u001b[39m\u001b[33m'\u001b[39m)\n",
      "\u001b[36mFile \u001b[39m\u001b[32m~/miniconda3/lib/python3.12/site-packages/IPython/core/interactiveshell.py:343\u001b[39m, in \u001b[36m_modified_open\u001b[39m\u001b[34m(file, *args, **kwargs)\u001b[39m\n\u001b[32m    336\u001b[39m \u001b[38;5;28;01mif\u001b[39;00m file \u001b[38;5;129;01min\u001b[39;00m {\u001b[32m0\u001b[39m, \u001b[32m1\u001b[39m, \u001b[32m2\u001b[39m}:\n\u001b[32m    337\u001b[39m     \u001b[38;5;28;01mraise\u001b[39;00m \u001b[38;5;167;01mValueError\u001b[39;00m(\n\u001b[32m    338\u001b[39m         \u001b[33mf\u001b[39m\u001b[33m\"\u001b[39m\u001b[33mIPython won\u001b[39m\u001b[33m'\u001b[39m\u001b[33mt let you open fd=\u001b[39m\u001b[38;5;132;01m{\u001b[39;00mfile\u001b[38;5;132;01m}\u001b[39;00m\u001b[33m by default \u001b[39m\u001b[33m\"\u001b[39m\n\u001b[32m    339\u001b[39m         \u001b[33m\"\u001b[39m\u001b[33mas it is likely to crash IPython. If you know what you are doing, \u001b[39m\u001b[33m\"\u001b[39m\n\u001b[32m    340\u001b[39m         \u001b[33m\"\u001b[39m\u001b[33myou can use builtins\u001b[39m\u001b[33m'\u001b[39m\u001b[33m open.\u001b[39m\u001b[33m\"\u001b[39m\n\u001b[32m    341\u001b[39m     )\n\u001b[32m--> \u001b[39m\u001b[32m343\u001b[39m \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mio_open\u001b[49m\u001b[43m(\u001b[49m\u001b[43mfile\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43m*\u001b[49m\u001b[43margs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43m*\u001b[49m\u001b[43m*\u001b[49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n",
      "\u001b[31mFileNotFoundError\u001b[39m: [Errno 2] No such file or directory: './compare_result/aefp.txt'"
     ]
    }
   ],
   "source": [
    "compare_list = ['aefp', 'aeq1p4', 'vqvae', 'bnn']\n",
    "\n",
    "for i in range (len(compare_list)):\n",
    "    reading_result(compare_list[i], 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "e8e0c46e-d5de-4519-a6e5-22d9c6772a23",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "19.23 $\\pm$ 0.07 / 18.37 $\\pm$ 0.13 & 3.18 $\\pm$ 0.08 / 4.43 $\\pm$ 0.13 & 0.12 $\\pm$ 0.00 / 0.13 $\\pm$ 0.00\n"
     ]
    }
   ],
   "source": [
    "for i in range (len(compare_list)):\n",
    "    reading_result(compare_list[i], 1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bc6f5beb-0da9-46d2-9e51-3350c9b65be3",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
