{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "5 clean files processed.\n",
      "5 poisoned files processed.\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import os \n",
    "import sys\n",
    "import numpy as np \n",
    "import matplotlib.pyplot as plt\n",
    "from tqdm import tqdm\n",
    "from sklearn.metrics import roc_curve, roc_auc_score, auc\n",
    "import matplotlib.pyplot as plt\n",
    "from typing import Tuple\n",
    "os.chdir(\"/data/home/Haoran/guardrail/TaskTracker\")\n",
    "\n",
    "#update constants in task_tracker.training.utils.constants and task_tracker.config.models\n",
    "from task_tracker.training.utils.constants import TEST_ACTIVATIONS_DIR_PER_MODEL,TEST_CLEAN_FILES_PER_MODEL,TEST_POISONED_FILES_PER_MODEL\n",
    "from task_tracker.training.dataset import ActivationsDatasetDynamicPrimaryText\n",
    "\n",
    "#update paths of trained models in task_tracker.experiments_outputs\n",
    "from task_tracker.experiments_outputs import LINEAR_PROBES_PATHS_PER_MODEL\n",
    "\n",
    "\n",
    "FILES = 'test'\n",
    "MODEL = 'phi3'\n",
    "\n",
    "\n",
    "# Path to output dirs \n",
    "output_dir = f'./images/{FILES}/{MODEL}'\n",
    "metrics_output_dir = f'./metrics/{FILES}/{MODEL}'\n",
    "os.makedirs(output_dir,exist_ok=True)\n",
    "os.makedirs(metrics_output_dir,exist_ok=True)\n",
    "\n",
    "metrics_file_path = os.path.join(metrics_output_dir, f'{MODEL}_{FILES}_model_metrics.csv')\n",
    "\n",
    "\n",
    "\n",
    "print(f'{len(TEST_CLEAN_FILES_PER_MODEL[MODEL])} clean files processed.')\n",
    "print(f'{len(TEST_POISONED_FILES_PER_MODEL[MODEL])} poisoned files processed.')\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def load_evaluation_data(val_files_clean, val_files_poisoned, num_layers):\n",
    "    print(\"Loading validation datasets.\")\n",
    "    print(num_layers)\n",
    "    clean_dataset = ActivationsDatasetDynamicPrimaryText(val_files_clean, num_layers=num_layers, root_dir=TEST_ACTIVATIONS_DIR_PER_MODEL[MODEL])\n",
    "    poisoned_dataset = ActivationsDatasetDynamicPrimaryText(val_files_poisoned, num_layers=num_layers, root_dir=TEST_ACTIVATIONS_DIR_PER_MODEL[MODEL])\n",
    "\n",
    "    print(\"Processing validation datasets.\")\n",
    "    clean_diff = []\n",
    "    for primary, clean_with_text in tqdm(clean_dataset):\n",
    "        #models with bfloat16 \n",
    "        if MODEL == 'phi3' or MODEL == 'llama3_70b':\n",
    "            clean_diff.append((clean_with_text - primary).flatten().float().numpy())\n",
    "        else:\n",
    "            clean_diff.append((clean_with_text - primary).flatten().numpy())\n",
    "    poisoned_diff = []\n",
    "    for primary, poisoned_with_text in tqdm(poisoned_dataset):\n",
    "        #models with bfloat16\n",
    "        if MODEL == 'phi3' or MODEL == 'llama3_70b': #these were bfloat16\n",
    "            poisoned_diff.append((poisoned_with_text - primary).flatten().float().numpy())\n",
    "        else:\n",
    "            poisoned_diff.append((poisoned_with_text - primary).flatten().numpy())\n",
    "    X_validation = np.array(clean_diff + poisoned_diff)\n",
    "    y_validation = [0]*len(clean_diff) + [1]*len(poisoned_diff)\n",
    "\n",
    "    return X_validation, y_validation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "def create_roc(fpr, tpr, roc_auc, num_layers):\n",
    "    # Plot ROC curve\n",
    "    plt.figure()\n",
    "    plt.plot(fpr, tpr, color='darkorange', lw=2, label='ROC curve (area = %0.2f)' % roc_auc)\n",
    "    plt.plot([0, 1], [0, 1], color='navy', lw=2, linestyle='--')\n",
    "    plt.xlim([0.0, 1.0])\n",
    "    plt.ylim([0.0, 1.05])\n",
    "    plt.xlabel('False Positive Rate')\n",
    "    plt.ylabel('True Positive Rate')\n",
    "    plt.title(f'Receiver Operating Characteristic for Layer {num_layers}')\n",
    "    plt.legend(loc=\"lower right\")\n",
    "        \n",
    "    # Save the ROC curve as an image file\n",
    "    roc_curve_path = os.path.join(output_dir, f'roc_curve_layer_{num_layers}.png')\n",
    "    plt.savefig(roc_curve_path)\n",
    "    plt.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "def evaluation(model, model_name: str,  X_test, y_test, num_layers: Tuple[int, int]):\n",
    "    print(\"Loading evaluation dataset.\")\n",
    "    y_pred_prob = model.predict_proba(X_test)[:, 1]\n",
    "    \n",
    "    fpr, tpr, _ = roc_curve(y_test, y_pred_prob)\n",
    "    print(y_pred_prob[0:2000])\n",
    "    roc_auc = auc(fpr, tpr)\n",
    "    \n",
    "    create_roc(fpr, tpr, roc_auc,num_layers)\n",
    "    \n",
    "    # Log ROC AUC score\n",
    "    roc_auc_score_value = roc_auc_score(y_test, y_pred_prob)\n",
    "    with open(metrics_file_path, 'a') as f:\n",
    "        f.write(f\"Model: {model_name}, Layer: {num_layers}, ROC AUC Score: {roc_auc_score_value}, ROC AUC: {roc_auc}, TPR: {tpr}, FPR: {fpr}\\n\")\n",
    "\n",
    "    print(f\"ROC AUC Score for Layer {num_layers}: {roc_auc_score_value}\")  \n",
    "    return fpr, tpr, roc_auc, roc_auc_score_value\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Processing model: /data/home/Haoran/guardrail/TaskTracker/store/model/Reconnaissance/phi3/0/model.pickle\n",
      "Loading validation datasets.\n",
      "(0, 0)\n",
      "Processing validation datasets.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 5000/5000 [00:00<00:00, 35708.48it/s]\n",
      "100%|██████████| 5000/5000 [00:00<00:00, 36426.85it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading evaluation dataset.\n",
      "[0.03519152 0.07363337 0.05209127 ... 0.05176204 0.12630178 0.07363337]\n",
      "ROC AUC Score for Layer 0: 0.9998304\n",
      "Processing model: /data/home/Haoran/guardrail/TaskTracker/store/model/Reconnaissance/phi3/7/model.pickle\n",
      "Loading validation datasets.\n",
      "(7, 7)\n",
      "Processing validation datasets.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 5000/5000 [00:00<00:00, 39116.26it/s]\n",
      "100%|██████████| 5000/5000 [00:00<00:00, 20824.29it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading evaluation dataset.\n",
      "[0.0002667  0.0001821  0.00102324 ... 0.00084954 0.00013442 0.0001821 ]\n",
      "ROC AUC Score for Layer 7: 1.0\n",
      "Processing model: /data/home/Haoran/guardrail/TaskTracker/store/model/Reconnaissance/phi3/15/model.pickle\n",
      "Loading validation datasets.\n",
      "(15, 15)\n",
      "Processing validation datasets.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 5000/5000 [00:00<00:00, 44233.07it/s]\n",
      "100%|██████████| 5000/5000 [00:00<00:00, 43539.19it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading evaluation dataset.\n",
      "[1.27490768e-04 6.18430629e-05 2.14369583e-04 ... 4.77011987e-05\n",
      " 4.26425312e-04 6.18430629e-05]\n",
      "ROC AUC Score for Layer 15: 1.0\n",
      "Processing model: /data/home/Haoran/guardrail/TaskTracker/store/model/Reconnaissance/phi3/23/model.pickle\n",
      "Loading validation datasets.\n",
      "(23, 23)\n",
      "Processing validation datasets.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 5000/5000 [00:00<00:00, 44280.52it/s]\n",
      "100%|██████████| 5000/5000 [00:00<00:00, 43633.13it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading evaluation dataset.\n",
      "[1.00491311e-05 1.40148810e-05 1.86644467e-05 ... 1.12946364e-05\n",
      " 1.25340470e-05 1.40148810e-05]\n",
      "ROC AUC Score for Layer 23: 1.0\n",
      "Processing model: /data/home/Haoran/guardrail/TaskTracker/store/model/Reconnaissance/phi3/31/model.pickle\n",
      "Loading validation datasets.\n",
      "(31, 31)\n",
      "Processing validation datasets.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 5000/5000 [00:00<00:00, 34827.16it/s]\n",
      "100%|██████████| 5000/5000 [00:00<00:00, 43587.51it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading evaluation dataset.\n",
      "[0.00024002 0.00034265 0.00018996 ... 0.00028254 0.000277   0.00034265]\n",
      "ROC AUC Score for Layer 31: 1.0\n"
     ]
    }
   ],
   "source": [
    "import pickle \n",
    "model_name = f'{MODEL}_Logistic_Regression'\n",
    "\n",
    "roc_data = []\n",
    "\n",
    "for model_path, layer in LINEAR_PROBES_PATHS_PER_MODEL[MODEL].items():\n",
    "    print(f\"Processing model: {model_path}\")\n",
    "    \n",
    "    # Load the model\n",
    "    model = pickle.load(open(model_path, 'rb'))\n",
    "        \n",
    "    # Load evaluation data\n",
    "    X_test, y_test = load_evaluation_data(TEST_CLEAN_FILES_PER_MODEL[MODEL], TEST_POISONED_FILES_PER_MODEL[MODEL], num_layers=(layer, layer))\n",
    "    \n",
    "    # Perform evaluation with ROC curve and ROC AUC score\n",
    "    fpr, tpr, roc_auc , roc_auc_score_value = evaluation(model, model_name, X_test, y_test, layer)\n",
    "    roc_data.append((fpr, tpr, roc_auc,roc_auc_score_value, layer))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 800x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saved combined ROC curve plot to ./images/test/phi3/roc_curve_combined.pdf\n"
     ]
    }
   ],
   "source": [
    "import matplotlib\n",
    "plt.rcParams.update({'font.size': 16})\n",
    "matplotlib.rcParams['pdf.fonttype'] = 42\n",
    "matplotlib.rcParams['ps.fonttype'] = 42\n",
    "\n",
    "roc_data.sort(key=lambda x: x[4])\n",
    "plt.figure(figsize=(8, 5))\n",
    "for fpr, tpr, roc_auc, roce_auc_score, n_layer in roc_data:\n",
    "    plt.plot(fpr, tpr, lw=2, label=f'Layer {n_layer} (area = {roc_auc:.4f})')\n",
    "\n",
    "\n",
    "plt.plot([0, 1], [0, 1], color='navy', lw=2, linestyle='--')\n",
    "plt.xlim([0.0, 1.0])\n",
    "plt.ylim([0.0, 1.05])\n",
    "plt.xlabel('False Positive Rate (FPR)', fontsize=14)\n",
    "plt.ylabel('True Positive Rate (TPR)', fontsize=14)\n",
    "\n",
    "plt.legend(loc=\"lower right\", fontsize=12)\n",
    "plt.grid(True)\n",
    "\n",
    "\n",
    "# Save the combined ROC curve plot\n",
    "roc_curve_combined_path = os.path.join(output_dir, 'roc_curve_combined.pdf')\n",
    "\n",
    "plt.savefig(roc_curve_combined_path, bbox_inches='tight')\n",
    "plt.show()\n",
    "plt.close()\n",
    "\n",
    "print(f\"Saved combined ROC curve plot to {roc_curve_combined_path}\")"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "taskdrift",
   "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.12.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
