{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "00082e05",
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "\n",
    "from pathlib import Path\n",
    "from utils.misc import get_output_dir,read_pickle\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "54b86af1",
   "metadata": {},
   "outputs": [],
   "source": [
    "out_dir = get_output_dir()\n",
    "experiment_folder = out_dir / \"darcy_experiment_snr_30\"\n",
    "\n",
    "methods = [\"FNO_FMPE_always_equispaced_True\", \"FNO_FMPE_always_equispaced_False_target_gridisize_2048\",\"spectral_NPE\",\"baseline_raw_FMPE\",\"baseline_spectral_FMPE\"]\n",
    "\n",
    "\n",
    "nsims = [1_000,3_000,10_000]\n",
    "param_dim = 129*129\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "245a7b12",
   "metadata": {},
   "outputs": [],
   "source": [
    "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",
    "            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",
    "            prior_log_prob_res = read_pickle(experiment_folder / method / f\"num_sim_{nsim}_run_{run}\" / f\"prior_log_probs.pkl\")\n",
    "            prior_log_probs = (prior_log_prob_res[\"prior_log_probs\"].view(-1)/param_dim).cpu().numpy()\n",
    "            if method in [\"FNO_FMPE_always_equispaced_True\",\"baseline_raw_FMPE\"]:\n",
    "                posterior_log_prob_res = read_pickle(experiment_folder / method / f\"num_sim_{nsim}_run_{run}\" / f\"posterior_log_probs.pkl\")\n",
    "                posterior_log_probs = (posterior_log_prob_res[\"posterior_log_probs\"]/param_dim).cpu().numpy()\n",
    "            else:\n",
    "                posterior_log_probs = np.nan\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\"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",
    "            print(f\"prior_log_probs: {prior_log_probs.shape}\")\n",
    "            print(f\"posterior_log_probs: {posterior_log_probs}\")\n",
    "\n",
    "            df = pd.concat([df, pd.DataFrame({\n",
    "                \"method\": method,\n",
    "                \"nsim\": nsim,\n",
    "                \"random_seed\": random_seed,\n",
    "                \"tarps\": tarp_absolute_atcs,\n",
    "                \"sbcs\": [sbc_absolute_atcs.cpu().numpy()],\n",
    "                \"predictive_mses\": [predictive_mse.cpu().numpy()],\n",
    "                \"prior_log_probs\": [prior_log_probs],\n",
    "                \"posterior_log_probs\": [posterior_log_probs],\n",
    "            },)], ignore_index=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2e2caaa3",
   "metadata": {},
   "outputs": [],
   "source": [
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ea2529a7",
   "metadata": {},
   "outputs": [],
   "source": [
    "df.to_csv(experiment_folder / \"summary_v1.csv\")\n",
    "df.to_pickle(experiment_folder / \"summary_v1.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
}
