{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d54caabb",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import json\n",
    "import pandas as pd\n",
    "\n",
    "ROOT_DIR = \"~/unlearning/cure_newton\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b27b0e21",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Load data for each sigma value and extract the last round statistics\n",
    "all_sigma_data = {}\n",
    "\n",
    "for sigma in [\"1e-3\", \"1e-2\", \"1e-1\", \"1\", \"10\", \"100\"]:\n",
    "    with open(f\"{ROOT_DIR}/sequential_unlearning/fashion_mnist_resize/by-class/seed-126/scr_newton_gdiff_sigma-{sigma}/stats.json\") as f:\n",
    "        stats = json.load(f)\n",
    "    \n",
    "    last_round_stats = stats[-1]\n",
    "    all_sigma_data[float(sigma)] = last_round_stats\n",
    "\n",
    "all_sigma_data = pd.DataFrame(all_sigma_data).T\n",
    "all_sigma_data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1cac6ca5",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.figure(figsize=(5, 3))\n",
    "plt.plot(all_sigma_data.index, all_sigma_data['test_acc'], marker='o', label='Test Accuracy')\n",
    "plt.plot(all_sigma_data.index, all_sigma_data['retain_acc'], marker='x', label='Retain Accuracy')\n",
    "plt.plot(all_sigma_data.index, all_sigma_data['forget_acc'], marker='v', label='Forget Accuracy')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "01ad78af",
   "metadata": {},
   "outputs": [],
   "source": [
    "import json\n",
    "import pandas as pd\n",
    "\n",
    "sigma_mean = {}\n",
    "sigma_std = {}\n",
    "for sigma in [\"1e-3\", \"1e-2\", \"1e-1\", \"1\", \"10\", \"100\"]:\n",
    "    sigma_results = []\n",
    "\n",
    "    for seed in [1, 2, 3]:\n",
    "        with open(f\"{ROOT_DIR}/sequential_unlearning/fashion_mnist_resize/by-class/seed-{seed}/scr_newton_gdiff_sigma-{sigma}/stats.json\") as f:\n",
    "            stats = json.load(f)\n",
    "        last_round_stats = stats[-1]\n",
    "        sigma_results.append(last_round_stats)\n",
    "\n",
    "    df = pd.DataFrame(sigma_results)\n",
    "    sigma_mean[sigma] = df.mean().to_dict()\n",
    "    sigma_std[sigma] = df.std().to_dict()\n",
    "        \n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d5e09c27",
   "metadata": {},
   "outputs": [],
   "source": [
    "pd.DataFrame(sigma_std).T"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "219c49de",
   "metadata": {},
   "outputs": [],
   "source": [
    "import json\n",
    "import pandas as pd\n",
    "\n",
    "retrain_res = []\n",
    "for seed in [125, 126, 127]:\n",
    "    with open(f\"{ROOT_DIR}/sequential_unlearning/fashion_mnist_resize/by-class/seed-{seed}/retraining/stats.json\") as f:\n",
    "        stats = json.load(f)\n",
    "    last_round_stats = stats[-1]\n",
    "    retrain_res.append(last_round_stats)\n",
    "\n",
    "df = pd.DataFrame(retrain_res)\n",
    "df.std()\n",
    "    "
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "unlearning",
   "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.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
