{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "303ddd54",
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "\n",
    "import numpy as np\n",
    "\n",
    "from pathlib import Path\n",
    "from utils.misc import get_output_dir,read_pickle\n",
    "import pandas as pd\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c6fd735c",
   "metadata": {},
   "outputs": [],
   "source": [
    "out_dir = get_output_dir()\n",
    "experiment_folder = out_dir/\"linear_gaussian\"\n",
    "methods = [\"FNO_FMPE_always_equispaced_False\",\"FNOPE_FMPE_always_equispaced_True\",\"spectral_NPE\",\"baseline_raw_FMPE\",\"baseline_spectral_FMPE\",\"raw_NPE\"]\n",
    "nsims = [1_000, 10_000, 100_000]\n",
    "\n",
    "df = pd.DataFrame()\n",
    "for method in methods:\n",
    "    for nsim in nsims:\n",
    "        for run in range(1,4):\n",
    "            print(method,nsim,run)\n",
    "\n",
    "            swd_res = read_pickle(experiment_folder / method / f\"num_sim_{nsim}_run_{run}\" / f\"swd_results.pkl\")\n",
    "            swds = swd_res[\"swd\"]\n",
    "            tarp_res = read_pickle(experiment_folder / method / f\"num_sim_{nsim}_run_{run}\" / f\"tarp_results.pkl\")\n",
    "            tarp_absolute_atcs = tarp_res[\"absolute_atcs\"]\n",
    "            sbc_res = read_pickle(experiment_folder / method / f\"num_sim_{nsim}_run_{run}\" / f\"sbc_results.pkl\")\n",
    "            sbc_absolute_atcs = sbc_res[\"absolute_atcs\"]\n",
    "            predictive_mse_res = read_pickle(experiment_folder / method / f\"num_sim_{nsim}_run_{run}\" / f\"predictive_check_results.pkl\")\n",
    "            predictive_mse = predictive_mse_res[\"mses\"]\n",
    "            random_seed_path = experiment_folder / method / f\"num_sim_{nsim}_run_{run}\" / f\"random_seed.csv\"\n",
    "            random_seed = int(np.loadtxt(random_seed_path, delimiter=\",\"))\n",
    "            print(f\"swd: {swds.shape}\")\n",
    "            print(f\"tarp: {tarp_absolute_atcs}\")\n",
    "            print(f\"sbc: {sbc_absolute_atcs.shape}\")\n",
    "            print(f\"predictive_mse: {predictive_mse.flatten().shape}\")\n",
    "            print(f\"random_seed: {random_seed}\")\n",
    "\n",
    "            df = pd.concat([df, pd.DataFrame({\n",
    "                \"method\": method,\n",
    "                \"nsim\": nsim,\n",
    "                \"random_seed\": random_seed,\n",
    "                \"swds\": [swds.cpu().numpy()],\n",
    "                \"tarps\": tarp_absolute_atcs,\n",
    "                \"sbcs\": [sbc_absolute_atcs.cpu().numpy()],\n",
    "                \"predictive_mses\": [predictive_mse.cpu().numpy()],\n",
    "            },)], ignore_index=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6100feba",
   "metadata": {},
   "outputs": [],
   "source": [
    "df\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2ca942a9",
   "metadata": {},
   "outputs": [],
   "source": [
    "df.to_csv(experiment_folder / \"summary.csv\")\n",
    "df.to_pickle(experiment_folder / \"summary.pkl\")"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "fourier_nets",
   "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.11.0"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
