{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 45,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle as pkl\n",
    "import numpy as np\n",
    "import os"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {},
   "outputs": [],
   "source": [
    "project_dir = '.'\n",
    "checkpoints_dir = 'checkpoint_archive'\n",
    "dataset_category = 'realworld'\n",
    "mae_pickle = 'test_mae.pkl'\n",
    "mae_e_pickle = 'test_mae_e.pkl'\n",
    "checkpoint_batch_indexs = ['1', '2', '3']\n",
    "\n",
    "dict_dataset_names = {\n",
    "    'synthetic': ['hawkes_1_v2', 'hawkes_2_v2', 'poisson_v2', 'self_correct_v2', 'stationary_renewal_v2'],\n",
    "    'realworld': ['bookorder', 'mooc', 'retweet', 'stackoverflow']\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {},
   "outputs": [],
   "source": [
    "for checkpoint_batch_index in checkpoint_batch_indexs:\n",
    "    selected_checkpoint_batch_dir = os.path.join(project_dir, checkpoints_dir, dataset_category, checkpoint_batch_index, 'output')\n",
    "    dataset_names = dict_dataset_names[dataset_category]\n",
    "    for dataset_name in dataset_names:\n",
    "        result_of_one_dataset = os.path.join(selected_checkpoint_batch_dir, dataset_name)\n",
    "        for result in os.listdir(result_of_one_dataset):\n",
    "            results_dir = os.path.join(result_of_one_dataset, result)\n",
    "\n",
    "            f_mae = open(os.path.join(results_dir, mae_pickle), 'rb')\n",
    "            mae = pkl.load(f_mae)\n",
    "            f_mae.close()\n",
    "\n",
    "            # We want the mean, var, Q1, Q2, and Q3 of MAE.\n",
    "            mae_array = mae.cpu().numpy()\n",
    "            mean, var = mae_array.mean(), mae_array.var()\n",
    "            Q1, Q2, Q3 = np.percentile(mae_array, [25, 50, 75]).tolist()\n",
    "            \n",
    "            f_report = open(os.path.join(results_dir, mae_report), 'w')\n",
    "            f_report.write(f'We announce the mean is {mean} with variance is {var}.\\n Q1: {Q1}, Q2: {Q2}, Q3: {Q3}.')\n",
    "            f_report.close()\n",
    "\n",
    "            # As some MTPP models do not have MAE-E evaluation part.\n",
    "            # We will try this part.\n",
    "            try:\n",
    "                f_mae_e = open(os.path.join(results_dir, mae_e_pickle), 'rb')\n",
    "                mae_e_array = pkl.load(f_mae_e)\n",
    "                f_mae_e.close()\n",
    "    \n",
    "                # We want the mean, var, Q1, Q2, and Q3 of MAE.\n",
    "                mean, var = mae_e_array.mean(), mae_e_array.var()\n",
    "                Q1, Q2, Q3 = np.percentile(mae_e_array, [25, 50, 75]).tolist()\n",
    "                \n",
    "                f_report = open(os.path.join(results_dir, mae_e_report), 'w')\n",
    "                f_report.write(f'We announce the mean is {mean} with variance is {var}.\\n Q1: {Q1}, Q2: {Q2}, Q3: {Q3}.')\n",
    "                f_report.close()\n",
    "            except:\n",
    "                continue\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.8.10"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
