{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "47e15eab-344e-4708-83eb-87b2e6aa69e2",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "_ROOT_PATH = os.path.join('..', '..', '..')\n",
    "_OPTIM_DIR = os.path.join(_ROOT_PATH, 'experiments', 'optim_ablation')\n",
    "_FINAL_DFS_DIR = os.path.join('..', '..', 'final_dfs')\n",
    "\n",
    "import sys\n",
    "sys.path.append('..')\n",
    "sys.path.append(os.path.join('..', '..', '..', 'tools'))\n",
    "import plotconfig"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "767a9d71-d33f-400e-8c5f-91d5043df5c1",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "dbf = os.path.join(_FINAL_DFS_DIR, 'optim_ablation.parquet')\n",
    "df = pd.read_parquet(dbf, engine='pyarrow')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bd96ae8d-f2db-4b12-83eb-a41a01cfc8ba",
   "metadata": {},
   "outputs": [],
   "source": [
    "import seaborn as sns\n",
    "\n",
    "df['str_ablation_distance'] = df['ablation_distance'].astype(str)\n",
    "df['combined'] = df['method_name'] + '-' + df['run_type'] + '-' + df['str_ablation_distance']\n",
    "\n",
    "# Define the interval for subsampling\n",
    "interval = 100\n",
    "numbers_to_keep = list(range(0, df['number'].max() + 1, interval))\n",
    "subsampled_df = df[df['number'].isin(numbers_to_keep)]\n",
    "\n",
    "# mask = ((subsampled_df['run_type'] == \"ablation\"))\n",
    "mask = ((subsampled_df['run_type'] == \"control\"))\n",
    "subsampled_df = subsampled_df[mask]\n",
    "\n",
    "ax = sns.lineplot(data=subsampled_df, x='number', y='value', hue='combined')\n",
    "\n",
    "ax.legend(loc='upper left', bbox_to_anchor=(1, 1))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "724a0075-0331-4c84-b36f-c39ba906ebfb",
   "metadata": {},
   "outputs": [],
   "source": [
    "import seaborn as sns\n",
    "\n",
    "# Define the interval for subsampling\n",
    "interval = 10\n",
    "numbers_to_keep = list(range(0, df['number'].max() + 1, interval))\n",
    "subsampled_df = df[df['number'].isin(numbers_to_keep)]\n",
    "\n",
    "# mask = ((subsampled_df['run_type'] == \"ablation\"))\n",
    "mask = ((subsampled_df['run_type'] == \"control\"))\n",
    "subsampled_df = subsampled_df[mask]\n",
    "\n",
    "ax = sns.lineplot(data=subsampled_df, x='number', y='euclidean_distance', hue='combined', errorbar='se')\n",
    "\n",
    "# ax.legend(loc='upper center', bbox_to_anchor=(0.6, 0.50),\n",
    "          # ncol=3, fancybox=True, shadow=True)\n",
    "\n",
    "ax.legend(loc='upper left', bbox_to_anchor=(1, 1))\n",
    "\n",
    "plt.xlabel('Optimisation iterations')\n",
    "plt.ylabel('Distance to ground truth')\n",
    "plt.title('Optimisation results')\n",
    "# \n",
    "# plt.xlim([-20, 2520])\n",
    "# plt.ylim([0, 5])\n",
    "# plt.xlim([-10, 50])\n",
    "# Save as high-definition\n",
    "# plotconfig.save_fig(\"optim_ablation\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f5d122a5-7bee-4dd8-abe8-7c32a5882180",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3b0c2441-fc98-460a-a5f3-6405dd36b590",
   "metadata": {},
   "outputs": [],
   "source": [
    "from scipy.spatial import distance\n",
    "import pickle\n",
    "\n",
    "result_df = pd.DataFrame()\n",
    "\n",
    "tmp = []\n",
    "fs = file_tools.list_files(_OPTIM_DIR, \"*.json\")\n",
    "for f in fs:\n",
    "    d = saving_tools.load_dict_from_json(f)\n",
    "\n",
    "    tmp.append((d['ablation_distance'], d['training_size']))\n",
    "\n",
    "set(tmp)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b042bdb2-eaee-457f-aa07-d6c24adaaa59",
   "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.9.19"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
