{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "fcdbea79-8c2e-435a-ab8a-6958a0b5b2d2",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "from matplotlib import pyplot as plt\n",
    "from sklearn import metrics\n",
    "import os\n",
    "import seaborn as sns\n",
    "from tqdm import tqdm\n",
    "\n",
    "try:\n",
    "    from io_utils import read_jsonlines\n",
    "except ModuleNotFoundError:\n",
    "    import os; os.chdir(\"..\")\n",
    "    from io_utils import read_jsonlines"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "b6267b64",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Reading JSON lines from outputs/est_err_det_sz1/memorized_prompts.jsonl: 100%|██████████| 500/500 [00:00<00:00, 11850.06lines/s]\n",
      "Reading JSON lines from outputs/est_err_det_sz1/non_memorized_prompts.jsonl: 100%|██████████| 500/500 [00:00<00:00, 15336.90lines/s]\n"
     ]
    }
   ],
   "source": [
    "mem_data = list(read_jsonlines(f\"outputs/est_err_det_sz1_sd15/memorized_prompts.jsonl\"))\n",
    "nonmem_data = list(read_jsonlines(f\"outputs/est_err_det_sz1_sd15/non_memorized_prompts.jsonl\"))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "db1328e8",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 500/500 [00:00<00:00, 16318.60it/s]\n",
      "100%|██████████| 500/500 [00:00<00:00, 20460.82it/s]\n"
     ]
    }
   ],
   "source": [
    "# aggregation\n",
    "all_data = [nonmem_data, mem_data]\n",
    "nonmem_df = []\n",
    "mem_df = []\n",
    "new_df = [nonmem_df, mem_df]\n",
    "\n",
    "start = 0 # the starting step to use\n",
    "end = 50 # the ending step to use\n",
    "num_gens = 4 # num of gens to use\n",
    "\n",
    "for i in range(len(all_data)):\n",
    "    curr_data = all_data[i]\n",
    "    curr_df = new_df[i]\n",
    "\n",
    "    # clean\n",
    "    for row in tqdm(curr_data):\n",
    "        new_row = {}\n",
    "        for key in row.keys():\n",
    "            if key == \"prompt\":\n",
    "                continue\n",
    "            \n",
    "            curr_data = np.array(row[key])\n",
    "            curr_data = curr_data[:num_gens, start:end]\n",
    "            curr_data = np.mean(curr_data, axis=0)\n",
    "\n",
    "            new_row[f\"{key}_mean\"] = np.mean(curr_data)\n",
    "\n",
    "        curr_df.append(new_row)\n",
    "\n",
    "all_keys = list(new_row.keys())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "519b5262-0647-4f72-adee-08162a1a96d4",
   "metadata": {},
   "outputs": [],
   "source": [
    "mem_df = pd.DataFrame(mem_df)\n",
    "mem_df[\"origin\"] = [\"Mem\"]*len(mem_df)\n",
    "\n",
    "nonmem_df = pd.DataFrame(nonmem_df)\n",
    "nonmem_df[\"origin\"] = [\"Non-Mem\"]*len(nonmem_df)\n",
    "\n",
    "all_dfs = [mem_df, nonmem_df]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "28fc4761-cc01-4745-9a82-d86946256802",
   "metadata": {},
   "outputs": [],
   "source": [
    "merged_df = pd.concat(all_dfs, ignore_index=True)\n",
    "merged_df = merged_df.replace(0, 0.01) # for log"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "2e1360e6-ea3b-4e4f-8cbf-9f30cdfbdc08",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "AUC: 0.998, ACC: 0.990, TPR@1%FPR: 0.986\n"
     ]
    },
    {
     "data": {
      "image/png": "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+dOf/tTgZyPAlClT6NevHxs2bODBBx/kgQceaLDg7Zlcf/31FBYWsmLFCgBWrFhBYWHhaevQFRUVcfnll9O7d2/Wrl3LF198QX5+PrfeemuD82bOnEliYiI//PADv/3tb3nggQe45ZZbGDx4MOvXr+eqq67irrvuory8/AJ/py6M4bOlxIOUHm3+NHD4ebZVmbqmRETO5YYbbiAzM5OnnnrqtNdefvllrrjiCv70pz/RsWNHxo8fz0MPPcRLL73U4LxRo0bx4IMP0r59ex5//HESExP55ptvznnvoKAg7rzzTqZNmwbAtGnTuPPOOwkKCmpw3htvvEHv3r15/vnn6dy5M71792batGl888037Ny5s/68Xr168eSTT9KhQweysrIIDQ0lMTGRCRMm0KFDByZPnszx48f56aefmvJbdd4UbsTBZnOMk2nuNHA4peVG4UZE5Hy8+OKLzJw5k23btjU4vm3bNoYMGdLg2JAhQ9i1axe1tbX1x3r27Fn/67qV/AsKHLNW67qSIiMjG139/5577mHu3Lnk5eUxd+5c7rnnntPO+fHHH/nmm2/qrxMZGUnnzp0B2LNnT6N1BAQEkJCQQI8ePeqPJScnA9TX5ioeN1tKDFJZBLaan4NJc4RGO57VciMicl4uvfRSRowYQVZWFuPHj7/g9/93S4vJZMJmswHw/vvvU1FR0eh5AD169KBz587cfvvtdOnShe7du7Nx48YG55SWlnLdddfx4osvnvb+li1bnrWOU4/V7QdZV5urKNyIQ/kJx7Mzwk1gGAQEa8yNiMgFeOGFF8jMzKRTp071x7p06cLKlSsbnLdy5Uo6duxIQEDAeV331GneZ3LPPffw4IMP8vbbbzf6ep8+ffj4449p27YtgYGeHx3ULSUOdUEkJKr51zKZHCGp7GjzryUi4id69OjBr371K1577bX6Y48++ihLlizhueeeY+fOncycOZM33niDxx57zKn3njBhAkePHj3j0ioTJ07kxIkT3H777axZs4Y9e/awaNEi7r777gbdY57C8+OXuEeFE1tuwDF2R91SImKkYjdtt+PE+zz77LN89NFH9V/36dOHf/3rX0yePJnnnnuOli1b8uyzzzap6+psAgMDSUxMPOPrrVq1YuXKlTz++ONcddVVWK1W2rRpw9VXX43Z7HntJCa7K5dA9EAWi4WYmBiKi4uJ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ERG3WL58Oddddx2tWrXCZDIxf/7808558803adu2LaGhoQwYMIAffvih/rUjR46Qmppa/3VqaiqHDx92R+ki4mUUbkTELcrKyujVqxdvvvlmo69/9NFHTJo0iaeeeor169fTq1cvRowYQUFBgZsrFRFvp3AjIm4xcuRI/vznP3PDDTc0+vrLL7/MhAkTuPvuu+natStTp04lPDycadOmAdCqVasGLTWHDx+mVatWbqldRLyLwo2IGK6qqop169YxfPjw+mNms5nhw4ezevVqAPr378/mzZs5fPgwpaWlfP7554wYMcKokkXEgxm+K7iIyLFjx6itrSU5ObnB8eTkZLZv3w5AYGAgU6ZM4bLLLsNms/GHP/xBM6VEpFEKNyLiNa6//nquv/56o8sQEQ+nbikRMVxiYiIBAQHk5+c3OJ6fn09KSopBVYmIt1K4ERHDBQcH07dvX5YsWVJ/zGazsWTJEgYNGmRgZSLijdQtJSJuUVpayu7du+u/3rdvHxs3biQ+Pp709HQmTZrEuHHj6NevH/379+fVV1+lrKyMu+++28CqRcQbafsFEXGLpUuXctlll512fNy4ccyYMQOAN954g5deeom8vDwyMzN57bXXGDBggJsrFRFvp3AjIiIiPkVjbkRERMSnKNyIiIiIT1G4EREREZ+icCMiIiI+ReFGREREfIrCjYiIiPgUhRsRERHxKQo3IiIi4lMUbkRERMSnKNyISL1hw4bxyCOPGF2GiEizKNyIiM94+umnyczMNLoMETGYwo2IiIj4FIUbEWlUYWEhY8eOJS4ujvDwcEaOHMmuXbvqXz9w4ADXXXcdcXFxRERE0K1bNz777LP69/7qV78iKSmJsLAwOnTowPTp08/rvjk5Odx6663ExsYSHx/P6NGj2b9/f/3rS5cupX///kRERBAbG8uQIUM4cOAAM2bM4JlnnuHHH3/EZDJhMpnqdxs/G5PJxDvvvMO1115LeHg4Xbp0YfXq1ezevZthw4YRERHB4MGD2bNnT4P3LViwgD59+hAaGspFF13EM888Q01NTf3rL7/8Mj169CAiIoK0tDQefPBBSktL61+fMWMGsbGxLFq0iC5duhAZGcnVV19Nbm7uef0+iciZKdyISKPGjx/P2rVr+b//+z9Wr16N3W5n1KhRVFdXAzBx4kSsVivLly9n06ZNvPjii0RGRgLwpz/9ia1bt/L555+zbds23n77bRITE895z+rqakaMGEFUVBTffvstK1eurP+hX1VVRU1NDWPGjGHo0KH89NNPrF69ml//+teYTCZuu+02Hn30Ubp160Zubi65ubncdttt5/VZn3vuOcaOHcvGjRvp3Lkzd9xxB/fffz9ZWVmsXbsWu93OQw89VH/+t99+y9ixY3n44YfZunUr77zzDjNmzOAvf/lL/Tlms5nXXnuNLVu2MHPmTL7++mv+8Ic/NLhveXk5f/3rX/n73//O8uXLOXjwII899th51SwiZ2EXETlp6NCh9ocffti+c+dOO2BfuXJl/WvHjh2zh4WF2f/1r3/Z7Xa7vUePHvann3660etcd9119rvvvvuC7//3v//d3qlTJ7vNZqs/ZrVa7WFhYfZFixbZjx8/bgfsS5cubfT9Tz31lL1Xr14XdE/A/uSTT9Z/vXr1ajtg/+CDD+qP/fOf/7SHhobWf33FFVfYn3/++dNqb9my5RnvM3fuXHtCQkL919OnT7cD9t27d9cfe/PNN+3JyckXVL+InC7Q0GQlIh5p27ZtBAYGMmDAgPpjCQkJdOrUiW3btgHwu9/9jgceeIAvv/yS4cOHc9NNN9GzZ08AHnjgAW666SbWr1/PVVddxZgxYxg8ePA57/vjjz+ye/duoqKiGhyvrKxkz549XHXVVYwfP54RI0Zw5ZVXMnz4cG699VZatmzZrM9bVzdAcnIyAD169GhwrLKyEovFQnR0ND/++CMrV65s0FJTW1tLZWUl5eXlhIeH89VXX5Gdnc327duxWCzU1NQ0eB0gPDycdu3a1V+jZcuWFBQUNOuziIi6pUSkie677z727t3LXXfdxaZNm+jXrx+vv/46ACNHjuTAgQP8/ve/58iRI1xxxRXn1d1SWlpK37592bhxY4PHzp07ueOOOwCYPn06q1evZvDgwXz00Ud07NiR7777rlmfJSgoqP7XJpPpjMdsNlt9nc8880yDGjdt2sSuXbsIDQ1l//79XHvttfTs2ZOPP/6YdevW8eabbwJQVVXV6H3r7mO325v1WURE4UZEGtGlSxdqamr4/vvv648dP36cHTt20LVr1/pjaWlp/OY3v2HevHk8+uijvPfee/WvJSUlMW7cOD788ENeffVV3n333XPet0+fPuzatYsWLVrQvn37Bo+YmJj683r37k1WVharVq2ie/fuzJ49G4Dg4GBqa2ud8Vtwzjp37NhxWo3t27fHbDazbt06bDYbU6ZMYeDAgXTs2JEjR464vC4RcVC4EZHTdOjQgdGjRzNhwgRWrFjBjz/+yJ133klqaiqjR48G4JFHHmHRokXs27eP9evX880339ClSxcAJk+ezIIFC9i9ezdbtmxh4cKF9a+dza9+9SsSExMZPXo03377Lfv27WPp0qX87ne/49ChQ+zbt4+srCxWr17NgQMH+PLLL9m1a1f9tdu2bcu+ffvYuHEjx44dw2q1uuT3Z/LkycyaNYtnnnmGLVu2sG3bNubMmcOTTz4JQPv27amurub1119n7969/P3vf2fq1KkuqUVETqdwIyKNmj59On379uXaa69l0KBB2O12Pvvss/qulNraWiZOnEiXLl24+uqr6dixI2+99RbgaEHJysqiZ8+eXHrppQQEBDBnzpxz3jM8PJzly5eTnp7OjTfeSJcuXbj33nuprKwkOjqa8PBwtm/fzk033UTHjh359a9/zcSJE7n//vsBuOmmm7j66qu57LLLSEpK4p///KdLfm9GjBjBwoUL+fLLL7n44osZOHAgr7zyCm3atAGgV69evPzyy7z44ot0796df/zjH2RnZ7ukFhE5ncmuDl4RERHxIWq5EREREZ+icCMibvP8888TGRnZ6GPkyJFOv98//vGPM96vW7duTr+fiHgGdUuJiNucOHGCEydONPpaWFgYqampTr1fSUkJ+fn5jb4WFBRUP0ZGRHyLwo2IiIj4FHVLiYiIiE9RuBERERGfonAjIiIiPkXhRkRERHyKwo2IiIj4FIUbERER8SkKNyIiIuJT/j8Gori9j34I+QAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "%matplotlib inline\n",
    "preds = []\n",
    "t_labels = []\n",
    "for j in range(len(all_dfs)):\n",
    "    curr_df = all_dfs[j]\n",
    "    curr_data = curr_df[\"loss_est_mean\"].values.tolist()\n",
    "    preds += curr_data\n",
    "    \n",
    "    if j == 0:\n",
    "        t_labels += [1] * len(curr_data)\n",
    "    else:\n",
    "        t_labels += [0] * len(curr_data)\n",
    "\n",
    "fpr, tpr, thresholds = metrics.roc_curve(t_labels, preds, pos_label=1)\n",
    "auc = metrics.auc(fpr, tpr)\n",
    "acc = np.max(1 - (fpr + (1 - tpr))/2)\n",
    "low = tpr[np.where(fpr<.01)[0][-1]]\n",
    "\n",
    "print('AUC: %.3f, ACC: %.3f, TPR@1%%FPR: %.3f' % (auc, acc, low))\n",
    "\n",
    "sns.kdeplot(data=merged_df[merged_df['origin'] == 'Mem'], x=\"loss_est_mean\", log_scale=True, fill=True, color='blue')\n",
    "sns.kdeplot(data=merged_df[merged_df['origin'] == 'Non-Mem'], x=\"loss_est_mean\", log_scale=True, fill=True, linestyle=\"--\", color='red')\n",
    "plt.xlabel(\"Loss value\")\n",
    "plt.legend(title=\"\", labels=[\"Memorized prompts\", \"Non-memorized prompts\"])\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4d6062a7",
   "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.10.14"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
